1、把连接MySQL数据库的jar文件,放到ActiveMQ的lib目录下

2、修改ActiveMQ的conf目录下的activemq.xml文件,修改数据持久化的方式
2.1 修改原来的kahadb的持久化数据的方式

  1. <!--
  2. <persistenceAdapter>
  3. <kahaDB directory="${activemq.data}/kahadb"/>
  4. </persistenceAdapter>
  5. -->
  6. <persistenceAdapter>
  7. <jdbcPersistenceAdapter dataSource="#mysql-ds"/>
  8. </persistenceAdapter>

2.2 连接Mysql的配置(注意配置文件放置的位置)

  1. <bean id="mysql-ds" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
  2. <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
  3. <property name="url" value="jdbc:mysql://localhost:3306/db?relaxAutoCommit=true"/>
  4. <property name="username" value="root"/>
  5. <property name="password" value="root"/>
  6. <property name="maxActive" value="200"/>
  7. <property name="poolPreparedStatements" value="true"/>
  8. </bean>

此时,重新启动MQ,就会发现db数据库中多了三张表:activemq_acks,activemq_lock,activemq_msgs,OK,说明activemq已经持久化成功啦!

1:activemq_acks:用于存储订阅关系。如果是持久化Topic,订阅者和服务器的订阅关系在这个表保存。
主要的数据库字段如下:

  1. container:消息的destination
  2. sub_dest:如果是使用static集群,这个字段会有集群其他系统的信息
  3. client_id:每个订阅者都必须有一个唯一的客户端id用以区分
  4. sub_name:订阅者名称
  5. selector:选择器,可以选择只消费满足条件的消息。条件可以用自定义属性实现,可支持多属性andor操作
  6. last_acked_id:记录消费过的消息的id

2:activemq_lock:在集群环境中才有用,只有一个Broker可以获得消息,称为Master Broker,其他的只能作为备份等待Master Broker不可用,才可能成为下一个Master Broker。这个表用于记录哪个Broker是当前的Master Broker。

3:activemq_msgs:用于存储消息,Queue和Topic都存储在这个表中。
主要的数据库字段如下:

  1. id:自增的数据库主键
  2. container:消息的destination
  3. msgid_prod:消息发送者客户端的主键
  4. msg_seq:是发送消息的顺序,msgid_prod+msg_seq可以组成jmsmessageid
  5. expiration:消息的过期时间,存储的是从1970-01-01到现在的毫秒数
  6. msg:消息本体的java序列化对象的二进制数据
  7. priority:优先级,从0-9,数值越大优先级越高
  8. activemq_acks用于存储订阅关系。如果是持久化topic,订阅者和服务器的订阅关系在这个表保存。
  1. package com.ljq.durian.test.activemq;
  2.  
  3. import javax.jms.Connection;
  4. import javax.jms.ConnectionFactory;
  5. import javax.jms.DeliveryMode;
  6. import javax.jms.Destination;
  7. import javax.jms.MessageProducer;
  8. import javax.jms.Session;
  9. import javax.jms.TextMessage;
  10.  
  11. import org.apache.activemq.ActiveMQConnectionFactory;
  12.  
  13. /**
  14. * 消息的生产者(发送者)
  15. *
  16. * @author Administrator
  17. *
  18. */
  19. public class JMSProducer {
  20.  
  21. public static void main(String[] args) {
  22. try {
  23. //第一步:建立ConnectionFactory工厂对象,需要填入用户名、密码、以及要连接的地址,均使用默认即可,默认端口为"tcp://localhost:61616"
  24. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("ljq", "ljq", "failover:(tcp://localhost:61616)?Randomize=false");
  25.  
  26. //第二步:通过ConnectionFactory工厂对象我们创建一个Connection连接,并且调用Connection的start方法开启连接,Connection默认是关闭的。
  27. Connection connection = connectionFactory.createConnection();
  28. connection.start();
  29.  
  30. //第三步:通过Connection对象创建Session会话(上下文环境对象),用于接收消息,参数配置1为是否启用是事务,参数配置2为签收模式,一般我们设置自动签收。
  31. Session session = connection.createSession(Boolean.TRUE, Session.CLIENT_ACKNOWLEDGE);
  32.  
  33. //第四步:通过Session创建Destination对象,指的是一个客户端用来指定生产消息目标和消费消息来源的对象,在PTP模式中,Destination被称作Queue即队列;在Pub/Sub模式,Destination被称作Topic即主题。在程序中可以使用多个Queue和Topic。
  34. Destination destination = session.createQueue("HelloWorld");
  35.  
  36. //第五步:我们需要通过Session对象创建消息的发送和接收对象(生产者和消费者)MessageProducer/MessageConsumer。
  37. MessageProducer producer = session.createProducer(null);
  38.  
  39. //第六步:我们可以使用MessageProducer的setDeliveryMode方法为其设置持久化特性和非持久化特性(DeliveryMode),我们稍后详细介绍。
  40. producer.setDeliveryMode(DeliveryMode.PERSISTENT);
  41.  
  42. //第七步:最后我们使用JMS规范的TextMessage形式创建数据(通过Session对象),并用MessageProducer的send方法发送数据。同理客户端使用receive方法进行接收数据。最后不要忘记关闭Connection连接。
  43.  
  44. for(int i = 0 ; i < 1 ; i ++){
  45. TextMessage msg = session.createTextMessage("我是消息内容" + i);
  46. // 第一个参数目标地址
  47. // 第二个参数 具体的数据信息
  48. // 第三个参数 传送数据的模式
  49. // 第四个参数 优先级
  50. // 第五个参数 消息的过期时间
  51. producer.send(destination, msg, DeliveryMode.PERSISTENT, 0 , 1000L*60);
  52. System.out.println("发送消息:" + msg.getText());
  53. session.commit(); //启用事务时记得提交事务,不然消费端接收不到消息
  54. Thread.sleep(1000);
  55. }
  56.  
  57. if(connection != null){
  58. connection.close();
  59. }
  60. } catch (Exception e) {
  61. e.printStackTrace();
  62. }
  63.  
  64. }
  65.  
  66. }
  1. package com.ljq.durian.test.activemq;
  2.  
  3. import javax.jms.Connection;
  4. import javax.jms.ConnectionFactory;
  5. import javax.jms.Destination;
  6. import javax.jms.MessageConsumer;
  7. import javax.jms.Session;
  8. import javax.jms.TextMessage;
  9.  
  10. import org.apache.activemq.ActiveMQConnectionFactory;
  11.  
  12. /**
  13. * 消息的消费者(接受者)
  14. *
  15. * @author Administrator
  16. *
  17. */
  18. public class JMSConsumer {
  19.  
  20. public static void main(String[] args) {
  21. try {
  22. //第一步:建立ConnectionFactory工厂对象,需要填入用户名、密码、以及要连接的地址,均使用默认即可,默认端口为"tcp://localhost:61616"
  23. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("ljq", "ljq", "failover:(tcp://localhost:61616)?Randomize=false");
  24.  
  25. //第二步:通过ConnectionFactory工厂对象我们创建一个Connection连接,并且调用Connection的start方法开启连接,Connection默认是关闭的。
  26. Connection connection = connectionFactory.createConnection();
  27. connection.start();
  28.  
  29. //第三步:通过Connection对象创建Session会话(上下文环境对象),用于接收消息,参数配置1为是否启用是事务,参数配置2为签收模式,一般我们设置自动签收。
  30. Session session = connection.createSession(Boolean.TRUE, Session.CLIENT_ACKNOWLEDGE); //Boolean.TRUE:消息持久化到activemq_msgs表,Boolean.FALSE:消息处理完成把该条记录删除
  31.  
  32. //第四步:通过Session创建Destination对象,指的是一个客户端用来指定生产消息目标和消费消息来源的对象,在PTP模式中,Destination被称作Queue即队列;在Pub/Sub模式,Destination被称作Topic即主题。在程序中可以使用多个Queue和Topic。
  33. Destination destination = session.createQueue("HelloWorld");
  34. //第五步:通过Session创建MessageConsumer
  35. MessageConsumer consumer = session.createConsumer(destination);
  36.  
  37. while(true){
  38. TextMessage msg = (TextMessage)consumer.receive();
  39. if(msg == null) {
  40. break;
  41. }
  42. msg.acknowledge();
  43. System.out.println("收到的内容:" + msg.getText());
  44. }
  45. } catch (Exception e) {
  46. e.printStackTrace();
  47. }
  48.  
  49. }
  50.  
  51. }

ActiveMQ消息持久化到Mysql数据库的更多相关文章

  1. ActiveMQ 消息持久化到Mysql数据库

    [root@txylucky local]# tar -zxvf apache-activemq-5.15.8-bin.tar.gz[root@txylucky local]# mv apache-a ...

  2. JMS学习九(ActiveMQ的消息持久化到Mysql数据库)

    1.将连接Mysql数据库的jar文件,放到ActiveMQ的lib目录下 2.修改ActiveMQ的conf目录下的active.xml文件,修改数据持久化的方式 2.1  修改原来的kshadb的 ...

  3. ActiveMQ 消息持久化到数据库(Mysql、SQL Server、Oracle、DB2等)

    ActiveMQ具体就不介绍了,直接介绍如何讲ActiveMQ持久化到本地数据库,以SQL Server 2008 R2为例1.下载ActiveMQ后直接解压,我下载的是apache-activemq ...

  4. ActiveMQ学习系列(四)----消息持久化到mysql

    前记:目前学习还比较杂乱,还未找到系统化地学习ActiveMq的方法.在网上看到消息持久化的demo,了解了一下,在此记录. 一.目前ActiveMq支持的持久化方法 url:http://activ ...

  5. JMS学习八(ActiveMQ消息持久化)

    ActiveMQ的消息持久化机制有JDBC,AMQ,KahaDB和LevelDB,还有一种内存存储的方式,由于内存不属于持久化范畴,而且如果使用内存队列,可以考虑使用更合适的产品,如ZeroMQ.所以 ...

  6. Springboot+ActiveMQ(ActiveMQ消息持久化,保证JMS的可靠性,消费者幂等性)

    ActiveMQ 持久化设置: 在redis中提供了两种持久化机制:RDB和AOF 两种持久化方式,避免redis宕机以后,能数据恢复,所以持久化的功能 对高可用程序来说 很重要. 同样在Active ...

  7. Activemq消息持久化

    官方文档: http://activemq.apache.org/persistence.html ActiveMq持久化相关配置:/usr/local/apache-activemq-5.11.1/ ...

  8. ActiveMQ消息持久化存储策略

    ActiveMQ的内核是Java编写的,也就是说如果服务端没有Java运行环境ActiveMQ是无法运行的.ActiveMQ启动时,启动脚本使用wrapper包装器来启动JVM.JVM相关的配置信息在 ...

  9. ActiveMQ(4) ActiveMQ JDBC 持久化 Mysql 数据库

    ActiveMQ 消息持久化机制: ActiveMQ 消息的持久化机制有 JDBC.AMQ.KahaDB 和 LevelDB,其中本示例版本(5.15.2)默认机制为 KahaDB.无论哪种持久化机制 ...

随机推荐

  1. Lucene.net 性能《第八篇》

    一.IndexReader性能分析 IndexReader完成了打开所有索引文件和提供底层reader API等繁重的工作,而IndexSearch则要简单得多.由于打开一个IndexReader需要 ...

  2. sine

       

  3. [Zend Mail]发送中文名附件出现乱码解决方案

    Zend Framework 1.0.* “=?UTF-8?B?”.base64_encode($title).“?=” 发送中文名附件,结果如图: 英文名附件,结果截图: 解决办法就是将中文文件名拼 ...

  4. Android-DateUtil工具类

    时间相关工具类 public class DateUtil { private DateUtil(){} /** * 枚举日期格式 */ public enum DatePattern{ /** * ...

  5. android RadioButton文字居中的方法

    每个RadioButton的style原先是这样的: <style name="radiobutton_style" > <item name="and ...

  6. sql service 备份

    declare @SqlBackupDataBase as nvarchar(1000)set @SqlBackupDataBase=N'BACKUP DATABASE YSKJ_Wechat TO ...

  7. Swagger 导出API

    Swagger 导出API 这算是在博客园的第一篇博客吧,之后发的应该也会同步到博客园上. 此前的博客地址: https://blog.mytyiluo.cn Swagger简介 Swagger是一个 ...

  8. Openwrt 远程调试

    此文已由作者吴志勐授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 本文以自己的程序WFD为例: 1,为路由器固件刷上gdbserver 在宿主端,使用make menucon ...

  9. 程序媛计划——mysql基本操作

    本文适用于mac 在官网上下载community 版mysql,选择dmy这种.在终端中安装好mysql. #进入mysql /usr/local/mysql/bin/mysql -uroot -p ...

  10. Mac OS 10.12 - 如何能够像在Windows一样切换中英文输入法和大小写键?

    最开始,我切换中英文输入法和大小写键是按照下面博客做到的: http://www.cnblogs.com/sunylat/p/6415563.html 但是当我安装完毕搜狗输入法后,切换中英文输入法和 ...