ActiveMQ使用JDBC持久化消息

为了避免服务器宕机而导致消息丢失,ActiveMQ提供消息持久化机制。

ActiveMQ提供多种消息持久化的方式,如LevelDB Store、KahaDB 、AMQ、JDBC等,详情可以访问官网

ActiveMQ默认是使用KahaDB持久化消息。在/conf/activemq.xml如下配置:

复制代码
<persistenceAdapter>
    <kahaDB directory="${activemq.data}/kahadb"/>
</persistenceAdapter>

KahaDB是一个文件型数据库,是以日志形式保存到文件来保证消息的持久化。


本篇博客主要介绍如果使用JDBC方式持久化消息,我选择MySQL作为存储数据库。

配置数据源

首先需要在mysql中新建数据库activemq,然后在/conf/activemq.xml配置如下数据源。注意在/lib目录下需要添加mysql-connector-java-5.1.44.jar、druid-1.1.9.jar两个Jar包,版本可自选。

复制代码
<bean id="mysql-ds" class="com.alibaba.druid.pool.DruidDataSource"
	 destroy-method="close">
	<property name="url" 
		value="jdbc:mysql://localhost:3306/activemq?relaxAutoCommit=true"/>
	<property name="username" value="root"/>
	<property name="password" value="root"/>
	<property name="initialSize" value="1" /> 
	<property name="minIdle" value="1" /> 
	<property name="maxActive" value="10" />
	<property name="poolPreparedStatements" value="true"/>
</bean>

引用数据源

复制代码
<!--
<persistenceAdapter>
    <kahaDB directory="${activemq.data}/kahadb"/>
</persistenceAdapter>
-->

<persistenceAdapter>
    <jdbcPersistenceAdapter dataSource="#mysql-ds" />
</persistenceAdapter>

启动

启动之后,数据库中就可以看见activemq_acks、activemq_lock、activemq_msgs三张表。

数据库信息

activemq_acks:存储订阅关系。

字段 类型 描述
CONTAINER varchar 消息的Destination
SUB_DEST varchar 如果是使用static集群,则会有集群其他系统的信息
CLIENT_ID varchar 每个订阅者的客户端ID
SUB_NAME varchar 订阅者名称
SELECTOR varchar 选择器,可以选择只消费满足条件的消息
LAST_ACKED_ID bigint 最后一次确认ID,该订阅者最后一次收到的消息的ID
PRIORITY bigint 优先级,值越大优先级越高
XID varchar --

activemq_msgs:存储消息。

字段 类型 描述
ID bigint 主键ID
CONTAINER varchar 消息的Destination
MSGID_PROD varchar 消息发送者客户端的主键
MSGID_SEQ bigint 发送消息的顺序,MSGID_PROD+MSG_SEQ可以组成JMS的MessageID
EXPIRATION bigint 消息的过期时间,存储的是从1970-01-01到现在的毫秒数
MSG longblob 消息内容
PRIORITY bigint 优先级,值越大优先级越高
XID varchar --

activemq_lock:存储锁信息。

字段 类型 描述
ID bigint 主键ID
TIME bigint 时间
BROKER_NAME varchar 拥有锁的Broker的名称
相关推荐
理人综艺好会17 小时前
双Token机制在实际项目中的应用与实践
中间件·token
番茄去哪了1 天前
神领物流面试题(一)
java·大数据·中间件
念何架构之路1 天前
消息中间件
中间件
都说名字长不会被发现1 天前
Spring Boot Starter 中间件账号密码加密方案设计与实现
java·spring boot·后端·中间件
瀚高PG实验室2 天前
java中间件无法连接数据库
java·数据库·中间件·瀚高数据库
之歆2 天前
Day11_Express 深入解析:从中间件到项目实战
中间件·express
码农飞哥2 天前
RocketMQ消费接口设计实战:为什么HTTP回调接口必须吞掉所有异常,始终返回成功?
网络协议·http·中间件·消息队列·rocketmq
硅谷秋水2 天前
物理人工智能的驾驭工程:机器人中间件是驾驭层
人工智能·机器学习·语言模型·中间件·机器人
初中就开始混世的大魔王3 天前
6 Fast DDS-传输层
开发语言·c++·中间件·信息与通信
zwh12984540603 天前
【 Fast-DDS 源码分析(一):架构总览与模块介绍】
中间件·架构