ActiveMQ安装配置及使用

ActiveMQ介绍

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。 
特性列表: 
⒈ 多种语言和协议编写客户端。语言: Java,C,C++,C#,Ruby,Perl,Python,PHP。应用协议: OpenWire,Stomp REST,WS Notification,XMPP,AMQP 
⒉ 完全支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务) 
⒊ 对spring的支持,ActiveMQ可以很容易内嵌到使用Spring的系统里面去,而且也支持Spring2.0的特性 
⒋ 通过了常见J2EE服务器(如 Geronimo,JBoss 4,GlassFish,WebLogic)的测试,其中通过JCA 1.5 resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上 
⒌ 支持多种传送协议:in-VM,TCP,SSL,NIO,UDP,JGroups,JXTA 
⒍ 支持通过JDBC和journal提供高速的消息持久化 
⒎ 从设计上保证了高性能的集群,客户端-服务器,点对点 
⒏ 支持Ajax 
⒐ 支持与Axis的整合 
⒑ 可以很容易的调用内嵌JMS provider,进行测试


(二)ActiveMQ安装、配置、启动、可视化界面

1、安装 
下载地址:http://activemq.apache.org/download.html 
2、配置(conf目录下) 
1)用户名密码设置 
 
2)开启jmx监控 
activemq.xml中进行如下修改 

注:这里的配置不是必须,根据需要自行配置 
3、启动 
直接运行bin目录下:activemq.bat 
4、可视化界面 
浏览器中:http://localhost:8161/admin/index.jsp 
用户名,密码在:jetty-realm.properties中设置


(三)点对点式消息队列(Queue)

消息生产者

  1. import javax.jms.Connection;
  2. import javax.jms.ConnectionFactory;
  3. import javax.jms.Destination;
  4. import javax.jms.JMSException;
  5. import javax.jms.MessageProducer;
  6. import javax.jms.Session;
  7. import javax.jms.TextMessage;
  8. import org.apache.activemq.ActiveMQConnectionFactory;
  9. public class QueueProducer {
  10. public static void main(String[] args) {
  11. //连接信息设置
  12. String username = "system";
  13. String password = "manager";
  14. String brokerURL = "failover://tcp://localhost:61616";
  15. //连接工厂
  16. ConnectionFactory connectionFactory = null;
  17. //连接
  18. Connection connection = null;
  19. //会话 接受或者发送消息的线程
  20. Session session = null;
  21. //消息的目的地
  22. Destination destination = null;
  23. //消息生产者
  24. MessageProducer messageProducer = null;
  25. //实例化连接工厂
  26. connectionFactory = new ActiveMQConnectionFactory(username, password, brokerURL);
  27. try {
  28. //通过连接工厂获取连接
  29. connection = connectionFactory.createConnection();
  30. //启动连接
  31. connection.start();
  32. //创建session
  33. session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
  34. //创建一个名称为QueueTest的消息队列
  35. destination = session.createQueue("QueueTest");
  36. //创建消息生产者
  37. messageProducer = session.createProducer(destination);
  38. //发送消息
  39. TextMessage message = null;
  40. for (int i=0; i<10; i++) {
  41. //创建要发送的文本信息
  42. message = session.createTextMessage("Queue消息测试" +(i+1));
  43. //通过消息生产者发出消息
  44. messageProducer.send(message);
  45. System.out.println("发送成功:" + message.getText());
  46. }
  47. session.commit();
  48. } catch (Exception e) {
  49. e.printStackTrace();
  50. }finally{
  51. if(null != connection){
  52. try {
  53. connection.close();
  54. } catch (JMSException e) {
  55. e.printStackTrace();
  56. }
  57. }
  58. }
  59. }
  60. }

消息消费者

  1. import javax.jms.Connection;
  2. import javax.jms.ConnectionFactory;
  3. import javax.jms.Destination;
  4. import javax.jms.JMSException;
  5. import javax.jms.MessageConsumer;
  6. import javax.jms.Session;
  7. import javax.jms.TextMessage;
  8. import org.apache.activemq.ActiveMQConnectionFactory;
  9. public class QueueConsumer {
  10. public static void main(String[] args) {
  11. //连接信息设置
  12. String username = "system";
  13. String password = "manager";
  14. String brokerURL = "failover://tcp://localhost:61616";
  15. //连接工厂
  16. ConnectionFactory connectionFactory = null;
  17. //连接
  18. Connection connection = null;
  19. //会话 接受或者发送消息的线程
  20. Session session = null;
  21. //消息的目的地
  22. Destination destination = null;
  23. //消息消费者
  24. MessageConsumer messageConsumer = null;
  25. //实例化连接工厂
  26. connectionFactory = new ActiveMQConnectionFactory(username, password, brokerURL);
  27. try {
  28. //通过连接工厂获取连接
  29. connection = connectionFactory.createConnection();
  30. //启动连接
  31. connection.start();
  32. //创建session
  33. session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
  34. //创建一个连接QueueTest的消息队列
  35. destination = session.createQueue("QueueTest");
  36. //创建消息消费者
  37. messageConsumer = session.createConsumer(destination);
  38. while (true) {
  39. TextMessage textMessage = (TextMessage) messageConsumer.receive(100000);
  40. if(textMessage != null){
  41. System.out.println("成功接收消息:" + textMessage.getText());
  42. }else {
  43. break;
  44. }
  45. }
  46. } catch (JMSException e) {
  47. e.printStackTrace();
  48. }
  49. }

(四)主题发布订阅式(Topic)

主题发布者

  1. import javax.jms.Connection;
  2. import javax.jms.ConnectionFactory;
  3. import javax.jms.DeliveryMode;
  4. import javax.jms.JMSException;
  5. import javax.jms.MessageProducer;
  6. import javax.jms.Session;
  7. import javax.jms.TextMessage;
  8. import javax.jms.Topic;
  9. import org.apache.activemq.ActiveMQConnectionFactory;
  10. public class TopicProducer {
  11. public static void main(String[] args) {
  12. //连接信息设置
  13. String username = "system";
  14. String password = "manager";
  15. String brokerURL = "failover://tcp://localhost:61616";
  16. //连接工厂
  17. ConnectionFactory connectionFactory = null;
  18. //连接
  19. Connection connection = null;
  20. //会话 接受或者发送消息的线程
  21. Session session = null;
  22. //消息的主题
  23. Topic topic = null;
  24. //消息生产者
  25. MessageProducer messageProducer = null;
  26. //实例化连接工厂
  27. connectionFactory = new ActiveMQConnectionFactory(username, password, brokerURL);
  28. try {
  29. //通过连接工厂获取连接
  30. connection = connectionFactory.createConnection();
  31. //启动连接
  32. connection.start();
  33. //创建session
  34. session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
  35. //创建名为TopicTest的主题
  36. topic = session.createTopic("TopicTest");
  37. //创建主题生产者
  38. messageProducer = session.createProducer(topic);
  39. messageProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);//不将数据持久化
  40. //发送主题
  41. TextMessage message = null;
  42. for (int i=0; i<10; i++) {
  43. //创建要发送的文本信息
  44. message = session.createTextMessage("Topic主题测试" +(i+1));
  45. //通过主题生产者发出消息
  46. messageProducer.send(message);
  47. System.out.println("发送成功:" + message.getText());
  48. }
  49. session.commit();
  50. } catch (Exception e) {
  51. e.printStackTrace();
  52. }finally{
  53. if(null != connection){
  54. try {
  55. connection.close();
  56. } catch (JMSException e) {
  57. e.printStackTrace();
  58. }
  59. }
  60. }
  61. }
  62. }

主题订阅者

  1. import javax.jms.Connection;
  2. import javax.jms.ConnectionFactory;
  3. import javax.jms.JMSException;
  4. import javax.jms.Message;
  5. import javax.jms.MessageConsumer;
  6. import javax.jms.MessageListener;
  7. import javax.jms.Session;
  8. import javax.jms.TextMessage;
  9. import javax.jms.Topic;
  10. import org.apache.activemq.ActiveMQConnectionFactory;
  11. public class TopicConsumer {
  12. public static void main(String[] args) {
  13. //连接信息设置
  14. String username = "system";
  15. String password = "manager";
  16. String brokerURL = "failover://tcp://localhost:61616";
  17. //连接工厂
  18. ConnectionFactory connectionFactory = null;
  19. //连接
  20. Connection connection = null;
  21. //会话 接受或者发送消息的线程
  22. Session session = null;
  23. //主题的目的地
  24. Topic topic = null;
  25. //主题消费者
  26. MessageConsumer messageConsumer = null;
  27. //实例化连接工厂
  28. connectionFactory = new ActiveMQConnectionFactory(username, password, brokerURL);
  29. try {
  30. //通过连接工厂获取连接
  31. connection = connectionFactory.createConnection();
  32. //启动连接
  33. connection.start();
  34. //创建session
  35. session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
  36. //创建一个连接TopicTest的主题
  37. topic = session.createTopic("TopicTest");
  38. //创建主题消费者
  39. messageConsumer = session.createConsumer(topic);
  40. messageConsumer.setMessageListener(new MyMessageListener());
  41. } catch (JMSException e) {
  42. e.printStackTrace();
  43. }
  44. }
  45. }
  46. class MyMessageListener implements MessageListener {
  47. @Override
  48. public void onMessage(Message message) {
  49. TextMessage textMessage = (TextMessage) message;
  50. try {
  51. System.out.println("接收订阅主题:" + textMessage.getText());
  52. } catch (JMSException e) {
  53. e.printStackTrace();
  54. }
  55. }
  56. }

注: 
1、代码中所需额外jar包在下载的mq文件夹中,例如我使用的:activemq-all-5.9.0.jar 
2、对于消息队列,异步生产和消费;对于主题发布订阅要先启动订阅者进行监听,然后在发布方可接收到订阅主题 
3、关于Queue与Topic的具体区别,详见http://blog.csdn.net/qq_21033663/article/details/52458305

ActiveMQ安装配置及使用 转发 https://www.cnblogs.com/hushaojun/p/6016709.html的更多相关文章

  1. ActiveMQ安装配置及使用

    ActiveMQ介绍 ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管J ...

  2. 1、windows安装npm教程 --参考自https://www.cnblogs.com/jianguo221/p/11487532.html

    windows安装npm教程   1.在使用之前,先类掌握3个东西,明白它们是用来干什么的: npm:  nodejs 下的包管理器. webpack: 它主要用途是通过CommonJS 的语法把所有 ...

  3. ActiveMQ安装配置及实例

    本文可作为吴水成老师,dubbo课程第21节的学习笔记. ActiveMQ的介绍及功能 参考百度 ActiveMQ的下载 https://activemq.apache.org/activemq-51 ...

  4. (jms)ActiveMQ 安装配置.

    前言 ActiveMQ他是Apache出品的一个JMS提供者,管理会话和队列,运行在JVM下,支持多种语言,如JAVA,C++,C#,应用协议: OpenWire,Stomp REST,WS Noti ...

  5. [转帖]Nginx安装及配置详解 From https://www.cnblogs.com/zhouxinfei/p/7862285.html

    Nginx安装及配置详解   nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP ...

  6. Nginx 安装配置证书,设置HTTPS站点

    详细配置如下: server { listen 80; server_name shwww.net www.shwww.net; return 301 https://www.shwww.net$re ...

  7. ActiveMQ发布订阅模式 转发 https://www.cnblogs.com/madyina/p/4127144.html

    ActiveMQ的另一种模式就SUB/HUB即发布订阅模式,是SUB/hub就是一拖N的USB分线器的意思.意思就是一个来源分到N个出口.还是上节的例子,当一个订单产生后,后台N个系统需要联动,但有一 ...

  8. Centos7:ActiveMQ安装,配置及使用

    解压缩ActiveMQ 的压缩包 使用 命令在bin目录下 ./activemq stat//开启 ./activemq stop//关闭 ./activemq status//状态 进入管理后台 U ...

  9. ElasticSearch(站内搜索) 转发 https://www.cnblogs.com/xibei666/p/5929970.html

    简介 Elasticsearch是一个实时的分布式搜索和分析引擎.它可以帮助你用前所未有的速度去处理大规模数据.它可以用于全文搜索,结构化搜索以及分析,当然你也可以将这三者进行组合.Elasticse ...

随机推荐

  1. 消息队列redis

    1.消息队列流程 2.接收用户请求 <?php header("Content-type:text/html;charset=utf-8"); //首先加载redis组键 $ ...

  2. 2017-11-09 中文代码示例之Vuejs入门教程(一)

    "中文编程"知乎专栏原链 为了检验中文命名在主流框架中的支持程度, 在vuejs官方入门教程第一部分的示例代码中尽量使用了中文命名. 所有演示都在本地测试通过, 源码在这里. 下面 ...

  3. Shell中判断语句if中-z至-d的意思

    [ -a FILE ] 如果 FILE 存在则为真. [ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真. [ -c FILE ] 如果 FILE 存在且是一个字特殊文件则为真. [ ...

  4. leetcode-67.二进制求和

    leetcode-67.二进制求和 Points 数组 数学 题意 给定两个二进制字符串,返回他们的和(用二进制表示). 输入为非空字符串且只包含数字 1 和 0. 示例 1: 输入: a = &qu ...

  5. Redis内存数据库快速入门

    Redis简介 Redis是一个开源(BSD许可),内存数据结构存储,用作数据库,缓存和消息代理.它支持数据结构,如 字符串,散列,列表,集合,带有范围查询的排序集,位图,超级日志,具有半径查询和流的 ...

  6. SQL中常用数学函数

    --1 RAND() 返回0到1的随机值,若不指定随机种子,返回值不同;若指定的种子相同则随机值相同SELECT RAND()SELECT RAND()SELECT RAND(100)SELECT R ...

  7. Windows服务器防火墙配置规范

    本文属于一篇内部规范文档,整理的初衷是为了规范.统一集团的Windows服务器(仅仅SQL Server数据库服务器)防火墙设置,仅仅供内部其它同事设置Windows防火墙时作为参考的文档资料.如有不 ...

  8. Windows Server 2016-Nano Server介绍

    WindowsServer 2016 提供了新的安装选项:Nano Server.Nano Server 是针对私有云和数据中心进行优化的远程管理的服务器操作系统. 类似于 Windows Serve ...

  9. python 爬虫 requests+BeautifulSoup 爬取巨潮资讯公司概况代码实例

    第一次写一个算是比较完整的爬虫,自我感觉极差啊,代码low,效率差,也没有保存到本地文件或者数据库,强行使用了一波多线程导致数据顺序发生了变化... 贴在这里,引以为戒吧. # -*- coding: ...

  10. no plugin found for prefix 'tomcat 7' in the current project and in the plugin groups的解决方法

    解决方法一: 找到这个settings.xml文件,进行编辑,在pluginGroups标签下加入下面的配置 <pluginGroups><pluginGroup>org.ap ...