点对点模式-消息生产者

点对点模式

点对点的模式主要建立在一个队列上面,当连接一个列队的时候,发送端不需要知道接收端是否正在接收,可以直接向ActiveMQ发送消息,发送的消息,将会先进入队列中,如果有接收端在监听,则会发向接收端,如果没有接收端接收,则会保存在activemq服务器,直到接收端接收消息,点对点的消息模式可以有多个发送端,多个接收端,但是一条消息,只会被一个接收端给接收到,哪个接收端先连上ActiveMQ,则会先接收到,而后来的接收端则接收不到那条消息。

消息生产者

(1)创建工程jmsDemo ,引入依赖

     <dependency>

         <groupId>org.apache.activemq</groupId>

         <artifactId>activemq-client</artifactId>

         <version>5.13.4</version>

     </dependency>

(2)创建类QueueProducer  main方法代码如下:

    //1.创建连接工厂

    ConnectionFactory connectionFactory=newActiveMQConnectionFactory("tcp://192.168.25.135:61616");

    //2.获取连接

    Connection connection = connectionFactory.createConnection();

    //3.启动连接

    connection.start();

    //4.获取session  (参数1:是否启动事务,参数2:消息确认模式)

    Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);   

    //5.创建队列对象

    Queue queue = session.createQueue("test-queue");

    //6.创建消息生产者

    MessageProducer producer = session.createProducer(queue);

    //7.创建消息

    TextMessage textMessage = session.createTextMessage("欢迎来到神奇的品优购世界");

    //8.发送消息

    producer.send(textMessage);

    //9.关闭资源

    producer.close();

    session.close();

    connection.close();

上述代码中第4步创建session  的两个参数:

第1个参数是否使用事务

第2个参数消息的确认模式

  • AUTO_ACKNOWLEDGE = 1    自动确认
  • CLIENT_ACKNOWLEDGE = 2    客户端手动确认
  • DUPS_OK_ACKNOWLEDGE = 3    自动批量确认
  • SESSION_TRANSACTED = 0    事务提交并确认

运行后通过ActiveMQ管理界面查询

 

猜你喜欢

转载自www.cnblogs.com/coder-wf/p/12518294.html