入门知识
http://www.cnblogs.com/chenpi/p/5559349.html
http://blog.csdn.net/jiuqiyuliang/article/details/46701559
queue和topic的区别
https://blog.csdn.net/u013760858/article/details/49638557
持久化和非持久化:
https://www.cnblogs.com/xinhuaxuan/p/6105985.html
发送方的基本用法:
1. ConnectionFactory -> Connection -> Session
2. Session -> Destination
Session + Destionation -> Producer
3. Session -> Message
Producer.send(Message)
接受方的基本用法:
1.ConnectionFactory -> Connection -> Session
2. Session -> Destination
Session + Destionation -> Consumer
3. Consumer.receive() or
实现Listener接口的onMessage方法,Consumer.addListener(new XXXListener())
Queue消息爆炸问题:
Queue里面的数据会一直存在,直到有消费者来消费。
Topic持久化问题:
默认是不持久化,每一个Topic就相当于服务器创建了一个即时聊天室,只要监听者不在线,消息发送方无论发送什么都会丢失,相当于白发了。
如果声明为持久化,服务器就会为这个topic维护一个监听者列表,只要在这个监听者列表中注册过的,如果消息来的时候,有监听者不在线,那就为它存一份,等到他上线了,就会发送给他。
如何声明为持久化:
发送方声明:producer.setDeliveryMode(DeliveryMode.PERSISTENT);
监听方注册:
connection.setClientID("con1"); //声明id
TopicSubscriber ts = session.createDurableSubscriber(destination, "TT"); //采用subscriber接口并声明名字
RocketMQ:可以保证多个监听,保证顺序
https://www.zhihu.com/question/30195969