java之消息队列ActiveMQ实践
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java之消息队列ActiveMQ实践,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4205字,纯文字阅读大概需要7分钟。
内容图文
原创论文: https://www.cnblogs.com/goujh/p/8510239.html
1、在安装ActiveMQ
http://activemq.apache.org/activemq-5158-release.html
2、解压启动服务
tar -zxvf apache-activemq-5.15.8-bin.tar.gz 进入目录,运行./bin/activemq start
3、网页查看
网址:http://139.199.64.189:8161/
点击:Manage ActiveMQ broker 输入默认用户和密码都为:admin
4、创建maven工程,在pom.xml文件中添加
<!-- https://mvnrepository.com/artifact/org.apache.activemq/activemq-core --> <dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-core</artifactId> <version>5.7.0</version> </dependency>
5、创建JMSConsumer.java文件,这是一个消费者
package com.activemq.demo.method1; import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.Destination; import javax.jms.MessageConsumer; import javax.jms.Session; import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnectionFactory; public class JMSConsumer { // 默认连接用户名 private static final String USERNAME = "admin";//ActiveMQConnection.DEFAULT_USER; //默认连接密码privatestaticfinal String PASSWORD = "admin";//ActiveMQConnection.DEFAULT_PASSWORD; //默认连接地址,默认端口为61616privatestaticfinal String BROKERURL = "tcp://ip:61616";//ActiveMQConnection.DEFAULT_BROKER_URL;publicstaticvoid main(String[] args) { //连接工厂 ConnectionFactory connectionFactory; //连接 Connection connection = null; //会话,接收或者发送消息的线程 Session session; //消息目的地 Destination destination; //消息的消费者 MessageConsumer messageConsumer; //实例化连接工厂 connectionFactory = new ActiveMQConnectionFactory(JMSConsumer.USERNAME, JMSConsumer.PASSWORD, JMSConsumer.BROKERURL); try { //通过工厂获取连接 connection = connectionFactory.createConnection(); //启动连接 connection.start(); //创建会话 session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //创建一个连接Hello World!的消息队列 destination = session.createQueue("Hello World"); //创建消息的消费者 messageConsumer = session.createConsumer(destination); while(true){ TextMessage textMessage = (TextMessage) messageConsumer.receive(100000); if (textMessage != null) { System.err.println("收到的消息:" + textMessage.getText()); } else { break; } } } catch (Exception e) { e.printStackTrace(); } } }
6、创建JMSProducer.java,这是一个生产者
package com.activemq.demo.method1; 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; public class JMSProducer { // 默认连接用户名 private static final String USERNAME = "admin";//ActiveMQConnection.DEFAULT_USER; //默认连接密码privatestaticfinal String PASSWORD = "admin";//ActiveMQConnection.DEFAULT_PASSWORD; //默认连接地址,默认端口为61616privatestaticfinal String BROKERURL = "tcp://ip:61616";//ActiveMQConnection.DEFAULT_BROKER_URL; //发送的消息数量privatestaticfinalint SENDNUM = 10; publicstaticvoid main(String[] args) { //连接工厂 ConnectionFactory connectionFactory; //连接 Connection connection = null; //会话,接收或者发送消息的线程 Session session; //消息的目的地 Destination destination; //消息生产者 MessageProducer messageProducer; //实例化连接工厂 connectionFactory = new ActiveMQConnectionFactory(JMSProducer.USERNAME, JMSProducer.PASSWORD, JMSProducer.BROKERURL); try { //通过连接工厂获取连接 connection = connectionFactory.createConnection(); //启动连接 connection.start(); //创建session session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE); //创建一个名称为Hello World!的消息队列 destination = session.createQueue("Hello World"); //创建消息生产者 messageProducer = session.createProducer(destination); //发送消息 sendMessage(session,messageProducer); session.commit(); } catch (Exception e) { e.printStackTrace(); } finally{ if(connection != null){ try { connection.close(); } catch (JMSException e) { e.printStackTrace(); } } } } /** * 发送消息 * @param session * @param messageProducer 消息生产者 * @throws Exception */publicstaticvoid sendMessage(Session session,MessageProducer messageProducer) throws Exception{ for (int i = 0; i < JMSProducer.SENDNUM; i++) { //创建一条文本消息 TextMessage message = session.createTextMessage("activemq 发送消息:" + i); System.err.println("发送消息:activemq 发送消息:" + i); //通过消息生产者发出消息 messageProducer.send(message); } } }
7、运行两个实例,可在web端查看
原文:https://www.cnblogs.com/ywjfx/p/10439039.html
内容总结
以上是互联网集市为您收集整理的java之消息队列ActiveMQ实践全部内容,希望文章能够帮你解决java之消息队列ActiveMQ实践所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。