下载windows版本ActiveMQ,apache-activemq-5.15.3\bin\win64\activemq.bat 启动mq,ActiveMQ内置jetty,默认端口8161,默认用户名密码admin、admin,在apache-activemq-5.15.3\conf\jetty-realm.properties 可修改登录用户密码。

访问控制台:http://localhost:8161/

java连接ActiveMQ代码

maven依赖:

  1. <dependency>
  2. <groupId>org.apache.activemq</groupId>
  3. <artifactId>activemq-all</artifactId>
  4. <version>5.15.3</version>
  5. </dependency>

消息接收者:

  1. package com.lhy.mq.helloworld;
  2.  
  3. import java.util.concurrent.TimeUnit;
  4.  
  5. import javax.jms.Connection;
  6. import javax.jms.ConnectionFactory;
  7. import javax.jms.Destination;
  8. import javax.jms.Message;
  9. import javax.jms.MessageConsumer;
  10. import javax.jms.Session;
  11. import javax.jms.TextMessage;
  12.  
  13. import org.apache.activemq.ActiveMQConnectionFactory;
  14.  
  15. public class Receiver {
  16.  
  17. public static void main(String[] args) throws Exception {
  18. //第一步:建立ConnectionFactory工厂对象。需要填入用户名、密码、连接地址,均使用默认即可,默认端口为"tcp://localhost:61616"
  19. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
  20. ActiveMQConnectionFactory.DEFAULT_USER,
  21. ActiveMQConnectionFactory.DEFAULT_PASSWORD,
  22. "tcp://localhost:61616");
  23.  
  24. //第二步:通过ConnectionFactory工厂对象,创建Connection连接,并调用Connection的start方法开启连接,Connection默认是关闭的
  25. Connection connection = connectionFactory.createConnection();
  26. connection.start();
  27.  
  28. //第三步:通过Connection对象创建Session会话(上下文环境对象),用于接收消息,参数配置1 为是否启用事物,参数配置2为签收模式,一般设置自动签收
  29. Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
  30.  
  31. //第四步:通过Session创建Destination对象,指的是一个客户端用来指定生产消息目标和消费消息来源的对象,
  32. //在PTP模式中,Destination被称作Queue即队列;在Pub/Sub模式,Destination被称作Topic即主题。
  33. //在程序中可以使用多个Queue和Topic
  34. Destination destination = session.createQueue("NB-Java");
  35.  
  36. //第五步:通过Session对象创建MessageConsumer
  37. MessageConsumer consumer = session.createConsumer(destination);
  38.  
  39. while(true){
  40. //阻塞状态
  41. TextMessage message = (TextMessage) consumer.receive();
  42. System.err.println("消费数据:"+message.getText());
  43. }
  44. }
  45. }

消息发送者:

  1. package com.lhy.mq.helloworld;
  2.  
  3. import java.util.concurrent.TimeUnit;
  4.  
  5. import javax.jms.Connection;
  6. import javax.jms.ConnectionFactory;
  7. import javax.jms.DeliveryMode;
  8. import javax.jms.Destination;
  9. import javax.jms.JMSException;
  10. import javax.jms.MessageProducer;
  11. import javax.jms.Queue;
  12. import javax.jms.Session;
  13. import javax.jms.TextMessage;
  14.  
  15. import org.apache.activemq.ActiveMQConnectionFactory;
  16.  
  17. public class Sender {
  18.  
  19. public static void main(String[] args) throws Exception {
  20.  
  21. //第一步:建立ConnectionFactory工厂对象。需要填入用户名、密码、连接地址,均使用默认即可,默认端口为"tcp://localhost:61616"
  22. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
  23. ActiveMQConnectionFactory.DEFAULT_USER,
  24. ActiveMQConnectionFactory.DEFAULT_PASSWORD,
  25. "tcp://127.0.0.1:61616");
  26.  
  27. //第二步:通过ConnectionFactory工厂对象,创建Connection连接,并调用Connection的start方法开启连接,Connection默认是关闭的
  28. Connection connection = connectionFactory.createConnection();
  29. connection.start();
  30.  
  31. //第三步:通过Connection对象创建Session会话(上下文环境对象),用于接收消息,参数配置1 为是否启用事物,参数配置2为签收模式,一般设置自动签收
  32. Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
  33.  
  34. //第四步:通过Session创建Destination对象,指的是一个客户端用来指定生产消息目标和消费消息来源的对象,
  35. //在PTP模式中,Destination被称作Queue即队列;在Pub/Sub模式,Destination被称作Topic即主题。
  36. //在程序中可以使用多个Queue和Topic
  37. Destination destination = session.createQueue("NB-Java"); //队列名称
  38.  
  39. //第五步:需要通过Session对象创建消息的发送和接收对象(生产者和消费者) MessageProducer/MessageConsumer
  40. //可以在创建生产者时指定 Destination目的地,这样发送的消息就都发到这,也可以在send消息的时候指定更灵活
  41. MessageProducer producer = session.createProducer(null);//
  42.  
  43. // 第六步:可以使用MessageProducer的setDeliveryMode方法为其设置持久化特性和非持久化特性(DeliveryMode)
  44. //producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
  45.  
  46. // 第七步:使用JMS规范的TextMessage形式创建数据(通过Session对象),调用MessageProducer的send方法发送数据。
  47. //同理客户端使用receive方式接收数据,最后关闭Connection连接
  48. for (int i = 0; i < 20; i++) {
  49. TextMessage message = session.createTextMessage("我是消息内容 - "+i);
  50. //message.setText(string);
  51. //第一个参数 目标地址
  52. //第二个参数 具体的数据信息
  53. //第三个参数 传送数据的模式
  54. //第四个参数 优先级
  55. //第五个参数 消息的过期时间
  56. // producer.send(destination, message, deliveryMode, priority, timeToLive);
  57.  
  58. producer.send(destination, message);
  59. TimeUnit.SECONDS.sleep(1);
  60.  
  61. System.err.println("生产者发送消息:"+message.getText());
  62. }
  63.  
  64. if(connection != null){
  65. connection.close();
  66. }
  67. }
  68.  
  69. }

修改客户端连接的用户名密码:

修改 apache-activemq-5.15.3\conf\activemq.xml,在broker 节点添加配置

  1. <plugins>
  2. <simpleAuthenticationPlugin>
  3. <users>
  4. <authenticationUser username="lhy" password="123456" groups="users,admins"/>
  5. </users>
  6. </simpleAuthenticationPlugin>
  7. </plugins>

生产者消费者再次就需要使用这个用户名密码了。

ActiveMQ会缓存没有消费的数据,就算服务停了再次启动还是可以拿到数据。

Active切换为mysql数据源

修改activemq.xml

  1. <persistenceAdapter>
  2. <!--持久化策略,默认是卡哈DB-->
  3. <!--<kahaDB directory="${activemq.data}/kahadb"/>-->
  4. <!--改为mysql,my-ds 是下边配置数据源bead的id-->
  5. <jdbcPersistenceAdapter dataSource="#my-ds"/>
  6. </persistenceAdapter>

再配置一个数据源的bean:在activemq.xml的beans节点下配置,使用了dbcp2 连接池

  1. <bean id="my-ds" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
  2. <property name="driverClassName" value="com.mysql.jdbc.Driver" />
  3. <property name="url" value="jdbc:mysql://127.0.0.1:3306/activemq?characterEncoding=utf-8" />
  4. <property name="username" value="root" />
  5. <property name="password" value="root" />
  6. <property name="initialSize" value="5" />
  7. <property name="maxTotal" value="100" />
  8. <property name="maxIdle" value="30" />
  9. <property name="maxWaitMillis" value="10000" />
  10. <property name="minIdle" value="1" />
  11. </bean>

下载mysql驱动包mysql-connector-java-5.1.8-bin.jar、dbcp包 commons-dbcp2-2.2.0.jar 放在apache-activemq-5.15.3\lib 下

注意建mysql数据库的时候,要设置编码为latin1 否则启动报错。

启动activeMQ, 会自动建2个表

再执行生成消息代码,可以看到mysql中存储了消息数据:

ActiveMQ API

1,Connection接口

2,Session接口

如果消息数量太多,可以多批次提交,如10万条数据,1000条提交一次,提高性能。

ActiveMQ--HelloWorld的更多相关文章

  1. ActiveMQ HelloWorld入门

    在P2P的消息模型中,双方通过队列交流,一个队列只有一个生产者和一个消费者.a.消息生产者 package com.ljq.durian.test.activemq; import javax.jms ...

  2. activeMQ "HelloWorld"实现

    本文主要介绍activeMQ在应用程序中是如何使用的,同个两个实例进行说明,这两个实例分别针对P2P模式和Pub/Sub模式. 开发环境 操作系统:Ubuntu 16.10 开发平台:Eclipse  ...

  3. ActiveMQ(2) ActiveMQ创建HelloWorld

    启动ActiveMQ: 请参见:ActiveMQ(1) 初识ActiveMQ 创建Maven工程: pom文件: <project xmlns="http://maven.apache ...

  4. ActiveMQ安装及使用

    1 安装环境 1.需要jdk2.安装Linux系统.生产环境都是Linux系统. 2 安装步骤 第一步: 把ActiveMQ 的压缩包上传到Linux系统.第二步:解压缩. 第三步:关闭防火墙 临时关 ...

  5. ActiveMQ(3) ActiveMQ创建(simpleAuthenticationPlugin)安全认证

    控制端安全认证: ActiveMQ目录conf下jetty.xml: <bean id="securityLoginService" class="org.ecli ...

  6. 深入浅出JMS(三)--ActiveMQ简单的HelloWorld实例

    第一篇博文深入浅出JMS(一)–JMS基本概念,我们介绍了JMS的两种消息模型:点对点和发布订阅模型,以及消息被消费的两个方式:同步和异步,JMS编程模型的对象,最后说了JMS的优点. 第二篇博文深入 ...

  7. JMS【三】--ActiveMQ简单的HelloWorld实例

    第一篇博文JMS[一]--JMS基本概念,我们介绍了JMS的两种消息模型:点对点和发布订阅模型,以及消息被消费的两个方式:同步和异步,JMS编程模型的对象,最后说了JMS的优点. 第二篇博文JMS[二 ...

  8. ActiveMQ简单的HelloWorld实例

    我们使用ActiveMQ为大家实现一种点对点的消息模型. 开发时候,要将apache-activemq-5.12.0-bin.zip解压缩后里面的activemq-all-5.12.0.jar包加入到 ...

  9. ActiveMQ 入门helloworld

    1.下载安装ActiveMQ 官网下载地址:http://activemq.apache.org/download.html ActiveMQ 提供了Windows 和Linux.Unix 等几个版本 ...

  10. 【转】深入浅出JMS(三)--ActiveMQ简单的HelloWorld实例

    这篇博文,我们使用ActiveMQ为大家实现一种点对点的消息模型.如果你对点对点模型的认识较浅,可以看一下第一篇博文的介绍. JMS其实并没有想象的那么高大上,看完这篇博文之后,你就知道什么叫简单,下 ...

随机推荐

  1. TabHost实现通话记录界面

    //MainActivity.java   public class MainActivity extends TabActivity   {       @Override       public ...

  2. qmake -简介

    qmake 简化了在不同平台下开发项目时构建处理的过程. qmake 自动产生Makefiles文件,只需要几行信息来构建每个Makefile.qmake可以被用于任何软件项目,不管是否使用Qt. q ...

  3. faceswap linux安裝教程

    http://www.mamicode.com/info-detail-2602743.html https://blog.csdn.net/sinat_26918145/article/detail ...

  4. struts2从浅之深(一)简介

    一.Struts2简介 1.Struts2概述                    Struts2是Apache发行的MVC开源框架.注意:它只是表现层(MVC)框架. M:model-----数据 ...

  5. H3C交换机流量镜像

    今天需要对交换机进行本地流量镜像,在此记录: 交换机:H3C S5120 配置本地端口镜像时,用户首先要创建一个本地镜像组,然后为本地镜像组配置源端口和目的端口. 表1-1 配置本地端口镜像 操作 命 ...

  6. 配置Jenkins构建失败触发邮件报警机制

    系统管理 1.进入系统管理-->系统设置 定位到Jenkins Location配置项   配置系统管理员邮件地址 系统管理员邮件地址需要同发送报警邮件地址相同 定位到邮件通知   配置SMTP ...

  7. Tomcat跨域访问配置

    下载cors-filter-1.7.jar,java-property-utils-1.9.jar这两个库文件,放到Tomcat的lib目录下. D:\Program Files\Tomcat-7.0 ...

  8. Dapper 嵌套对象查询

    我有这样一个一对一关系的表结构:User->UserInfo User: /// <summary> /// 用户 /// </summary> [Serializabl ...

  9. DevOps Workshop 研发运维一体化(成都站) 2016.05.08

    成都的培训与广州.上海.北京一样,只是会议室比较小,比较拥挤,大家都将就了.可惜换了电脑以后,没有找到培训时的照片了,遗憾. 培训思路基没有太大变化,基本按照下面的思路进行: 第一天对软件开发的需求管 ...

  10. 开源一款强大的文件服务组件(QJ_FileCenter)(系列一)

    系列文章 1. 开源一款强大的文件服务组件(QJ_FileCenter)(系列一) 2. 开源一款强大的文件服务组件(QJ_FileCenter)(系列二 安装说明) 3. 开源一款强大的文件服务组件 ...