MQ相关

2019-08-08  本文已影响0人  夏与清风
1、什么是消息队列?

消息队列是在消息的传输过程中保存消息的容器,用于接收消息并以文件的方式存储,一个队列的消息可以同时被多个消息消费者消费。分布式消息服务DMS则是分布式的队列系统,消息队列中的消息分布存储,且每条消息存储多个副本,以实现高可用性。
消息队列具有如下属性:

2、ActiveMQ的消息传递模式
3、中间件的分类
4、面向消息的中间件 (Message-Oriented Middleware, MOM)
消息队列中间件是分布式系统中重要的组件,主要解决应用耦合、异步消息、流量削锋等问题。实现高性能、高可用、可伸缩和最终一致性架构。是大型分布式系统不可缺少的中间件。 image.png
5、什么是jms?

JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。Java消息服务是一个与具体平台无关的API,绝大多数MOM提供商都对JMS提供支持。

6、JMS消息传送模式
image.png
7、JMS 消息传送对象
MS 消息传送的对象在编程域中基本保持不变:连接工厂、连接、会话、生成方、使用方、消息和目的地。 image.png
8、MQ (Message Queue)应用场景?
9、ActiveMQ简单案例

消息生产者:

//创建session会话
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
Connection connection = factory.createConnection();
connection.start();
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

//创建一个消息队列 session.createQueue("jms.test.topic")--P2P模式
Destination destination = session.createTopic("jms.test.topic");
//创建消息生产者
MessageProducer producer = session.createProducer(destination);

//消息持久化
producer.setDeliveryMode(DeliveryMode.PERSISTENT);
for (int i = 0; i < messageNum; i++)
  producer.send(session.createTextMessage("Message Producer:" + i));

session.commit(); //提交会话

消息消费者:

//创建session会话
ConnectionFactory factory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
Connection connection = factory.createConnection();
connection.start();
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

//创建一个消息队列 session.createQueue("jms.test.topic")--P2P模式
Destination destination = session.createTopic("jms.test.topic");
//创建消息消费者
MessageConsumer consumer = session.createConsumer(destination);
while (true) {
  TextMessage message = (TextMessage) consumer.receive();
  if (message != null) System.out.println("Message Consumer:"+message.getText());
  else break;
}
session.commit();
10、ActiveMQ的消息存储机制
11、ActiveMQ的部署模式
12、消息中间件的组成
13、消息中间件的优势
14、消息中间件常用协议
15、常见消息中间件MQ介绍
16、消息的ACK机制

ACK机制:消息的Ackownledge确认机制,为了保证消息不丢失,消息队列提供了消息Acknowledge机制,当Consumer确认消息已经被消费处理,发送一个ACK给消息队列,此时消息队列便可以删除这个消息了。如果Consumer宕机/关闭,没有发送ACK,消息队列将认为这个消息没有被处理,会将这个消息重新发送给其他的Consumer重新消费处理。

上一篇下一篇

猜你喜欢

热点阅读