ActiveMQ5.12使用Mysql8以上版本持久化

本文详细介绍了ActiveMQ中KahaDB和JDBC两种消息持久化方式,包括它们的文件结构、工作原理以及如何配置使用JDBC将消息持久化到MySQL数据库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Active默认消息持久化为KahaDB(5.4以后至5.12)5.3之前的版本使用AMQ

KahaDB为默认配置。在 {activeMQ}/data/kahadb/  目录下有5个类型的文件

1. log文件,记录消息内容,是可拆分的

2.data文件是对log的B树索引

3.free文件是记录空闲的位置(这里消费掉的消息要么删了,要么归档了。为了不产生碎片,充分利用空间,这里记录哪些位置空闲)

4.redo是为了在挂了或者重启之后恢复B树索引

5.lock文件是锁文件

 

ActiveMQ也支持JDBC持久化到Mysql数据库

1.在 {activeMQ}/lib 路径下放入mysql驱动包 官方下载地址(需要ORACLE账号)

 

2.修改 {activeMQ}/conf 路径下的active.xml配置文件

之前指定kahaDB的位置变成这样(这里指定在连接数据库时自动创建所需要的表)

  <persistenceAdapter>
          <jdbcPersistenceAdapter dataSource="#mysqlDB" createTablesOnStartup="true"  />
  </persistenceAdapter>

 在下面的<beans>标签中 import 标签之前加如下配置

<bean id="mysqlDB" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close" >
        <property name="driverClassName" value="com.mysql.cj.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://127.0.0.1:3306/activemq?relaxAutoCommit=true&amp;useSSL=false" />
        <property name="username" value="root" />
        <property name="password" value="root" />
        <property name="poolPreparedStatements" value="true"/>
</bean>

保存重启即可

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值