maven依赖
<dependencies> <dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-core</artifactId> <version>5.7.0</version> </dependency> </dependencies>
package com.toov5.subscribe; import javax.jms.Connection; import javax.jms.JMSException; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import javax.jms.Topic; import org.apache.activemq.ActiveMQConnectionFactory; public class producerTest { // mq通讯地址 private static String url = "tcp://192.168.91.6:61616"; // 消息名称 private static String topicName = "toov5_topic"; public static void main(String[] args) throws JMSException { // 先创建连接工厂 密码默认采用admin admin ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(url); // 创建连接 Connection connection = activeMQConnectionFactory.createConnection(); // 启动连接 connection.start(); // 创建会话 Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); // 是否需要事务方式提交 消费方式默认自动签收 // 拿到session 创建目标 创建主题 Topic topic =session.createTopic(topicName); // 创建生产者 MessageProducer producer = session.createProducer(topic); // 生产者生产的消息 是放在这个queue里面的 for (int i = 1; i < 10; i++) { // 拿到队列 创建消息 TextMessage textMessage = session.createTextMessage("消息内容" + i); // 发送消息 producer.send(textMessage); } // 关闭连接 connection.close(); System.out.println("消息发送完毕"); } }
结果:
发布订阅模式!先启动订阅 在启动发布!!!!!!
package com.toov5.subscribe; import javax.jms.Connection; import javax.jms.JMSException; import javax.jms.Message; import javax.jms.MessageConsumer; import javax.jms.MessageListener; import javax.jms.Session; import javax.jms.TextMessage; import javax.jms.Topic; import org.apache.activemq.ActiveMQConnectionFactory; public class consumerTest { // mq通讯地址 private static String url = "tcp://192.168.91.6:61616"; // 消息名称 private static String topicName = "toov5_topic"; public static void main(String[] args) throws JMSException { // 先创建连接工厂 密码默认采用admin admin ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(url); // 创建连接 Connection connection = activeMQConnectionFactory.createConnection(); // 启动连接 connection.start(); // 创建会话 Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); // 是否需要事务方式提交 消费方式默认自动签收 // 拿到session 创建目标 创建主题 Topic topic =session.createTopic(topicName); //创建消费者 MessageConsumer consumer = session.createConsumer(topic); //启动监听 监听消息 consumer.setMessageListener(new MessageListener() { public void onMessage(Message message) { //强制转换 TextMessage textMessage = (TextMessage) message; try { System.out.println("consumer 消费 producer:"+textMessage.getText()); } catch (JMSException e) { e.printStackTrace(); } } }); //监听时候 不要关闭连接 关闭就不监听了 一只处于监听状态 (长连接) } }
结果:
如果启动一个生产者 两个消费者 那么消费者消费都到的是一样的!
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/16177.html