到底什么是消息队列?Java中如何实现消息队列?


网上查了一些资料,感觉都是概念性的很空泛的东西,可是不知道到底是什么东西,如何在Java中实现并使用……

在此请教各位前辈到底什么是消息队列?Java中如何实现消息队列?

队列 java 消息队列

甜品战士柏木氏 9 years, 10 months ago

找本数据结构的书看看,队列是一种数据结构,内部是用数组或链表实现的,队列的特点是只能队头放入,队尾取出,即先入先出,具体应用看下生产者消费者

ぁ飛あ鳥ぇ answered 9 years, 10 months ago

来个个人通俗的解释吧。
消息队列,顾名思义 首先是个队列。
队列的操作有 入队 出队

也就是你有一个程序在产生内容然后入队(生产者)
另一个程序读取内容,内容出队(消费者)

这是最最基本的概念。

我想你应该是缺乏一个使用场景。

当你不需要立即获得结果,但是并发量又不能无限大的时候,差不多就是你需要使用消息队列的时候。

比如你写日志,因为可能一个客户端有多个操作去写,又有很多个客户端,显然并发不能无穷大,于是你就需要把写日志的请求放入到消息队列里,在消费者那边依次把队列中产生的日志写到数据库里。

至于怎么实现消息队列,其实你本身一个普通的队列就行呀~看你需要什么附加功能而已。

Sasuke℃ answered 9 years, 10 months ago

消息队列有无数开源实现,一般没必要自己实现。zmq也好rabbitmq也好甚至redis也好,找一个合适的装上用就行

就好像rdbms/nosql一样

技术都是解决问题的,消息队列解决的是将突发大量请求转换为后端能承受的队列请求,比如你的服务器一秒能处理100个订单,但秒杀活动1秒进来1000个订单,持续10秒,在后端能力无法增加的情况下,你可以用消息队列将总共10000个请求压在队列里,后台consumer按原有能力处理,100秒后处理完所有请求(而不是直接宕机丢失订单数据)

所以说首先别自己实现消息队列(在你用过各种消息队列,还看过一两份源码之前),其次没有合适的需求别用消息队列,YAGNI

大老板来了 answered 9 years, 10 months ago

Your Answer