activeMq实战
来源:互联网 发布:淘宝花呗有利息吗 编辑:程序博客网 时间:2024/05/16 14:10
jms模式为queues
如果消费者的session应答模式为AUTO_ACKNOWLEDGE,则javax.jms.MessageListener.onMessage(Message)出现异常会进入ActiveMQ.DLQ(死信队列)详见截图:
如果消费者的session应答模式为CLIENT_ACKNOWLEDGE,则javax.jms.MessageListener.onMessage(Message)手动调用 message.acknowledge();activemq才会标记已处理,除非该消费者断开连接消息重新发给其他消费者处理。
相关代码和环境如下:
centos7
jkd7
activemq5
maven3.2.5
生产者代码:
package com.bj58.jms.produce;import javax.jms.Connection;import javax.jms.ConnectionFactory;import javax.jms.Destination;import javax.jms.JMSException;import javax.jms.MessageProducer;import javax.jms.Session;import javax.jms.TextMessage;import org.apache.activemq.ActiveMQConnectionFactory;import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class ProducerApp { private static final Logger LOGGER = LoggerFactory .getLogger(ProducerApp.class); private static final String BROKER_URL = "tcp://192.168.146.128:61616"; private static final String SUBJECT = "demo"; public static void main(String[] args) throws JMSException { // 初始化连接工厂 ConnectionFactory connectionFactory = new ActiveMQConnectionFactory( BROKER_URL); // 获得连接 Connection conn = connectionFactory.createConnection(); // 启动连接 conn.start(); // 创建Session,此方法第一个参数表示会话是否在事务中执行,第二个参数设定会话的应答模式 Session session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE); // 创建队列 Destination dest = session.createQueue(SUBJECT); // createTopic方法用来创建Topic // session.createTopic("TOPIC"); // 通过session可以创建消息的生产者 MessageProducer producer = session.createProducer(dest); for (int i = 0; i < 10; i++) { // 初始化一个mq消息 TextMessage message = session .createTextMessage("sad轻轻巧巧fasmq 中文" + i); // 发送消息 producer.send(message); LOGGER.info("send message {}", i); } // 关闭mq连接 conn.close(); }}
消费者代码:
package com.bj58.jms.consumer;import org.apache.activemq.ActiveMQConnectionFactory;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import javax.jms.*;public class ConsumerApp implements MessageListener { private static final Logger LOGGER = LoggerFactory.getLogger(ConsumerApp.class); private static final String BROKER_URL = "tcp://192.168.146.128:61616"; private static final String SUBJECT = "demo"; public static void main(String[] args) throws JMSException { //初始化ConnectionFactory ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(BROKER_URL); //创建mq连接 Connection conn = connectionFactory.createConnection(); //启动连接 conn.start(); //创建会话 Session session = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE); //通过会话创建目标 Destination dest = session.createQueue(SUBJECT); //创建mq消息的消费者 MessageConsumer consumer = session.createConsumer(dest); //初始化MessageListener ConsumerApp me = new ConsumerApp(); //给消费者设定监听对象 consumer.setMessageListener(me); } public void onMessage(Message message) { TextMessage txtMessage = (TextMessage)message; int i=0; int [] arr={1,2};//if(i==0){//i=arr[2];// } try { LOGGER.info ("get message " + txtMessage.getText()); //告诉activemq 成功处理消息 message.acknowledge(); } catch (JMSException e) { LOGGER.error("error {}", e); } }}
代码包下载:http://pan.baidu.com/s/1kTuA9eB
0 0
- 实战activeMQ
- 实战activeMQ
- 实战activeMQ
- 实战activeMQ
- 实战activeMQ
- 实战activeMQ
- 实战activeMQ
- ActiveMQ实战
- activeMq实战
- 实战activeMQ
- ActiveMQ实战
- ActiveMQ实战(一)--ActiveMQ简介
- ActiveMQ实战1:ActiveMQ Java
- ActiveMQ实战之 安装
- ActiveMQ 八 (实战三)
- activeMQ 特点、实战
- (十)实战activeMQ
- ActiveMQ 实战笔记
- bimap转base64上传到服务器
- nginx 重中之重 event 模块
- ROS笔记
- 给Nginx配置一个自签名的SSL证书
- iOS开发 -- 添加自定义ttf字体的方法
- activeMq实战
- MFC程序 调用控制台 显示调试信息
- cocos 2d-x 3.0环境配置
- [Android] AsyncTask源码解析
- Android开发教程01:Android的系统构架及特性
- 字符串的一些判断
- GridControl 获取选中行的数量
- private static final long serialVersionUID = 1L;
- 如何编程实现二维图形的旋转