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 小时前
2.Express 核心语法与路由
中间件·node.js·express
feathered-feathered18 小时前
Redis【事务】(面试相关)与MySQL相比较,重点在Redis事务
android·java·redis·后端·mysql·中间件·面试
音符犹如代码19 小时前
深入解析 Apollo:微服务时代的配置管理利器
java·分布式·后端·微服务·中间件·架构
IMPYLH1 天前
Lua 的 Coroutine(协程)模块
开发语言·笔记·后端·中间件·游戏引擎·lua
脸大是真的好~2 天前
黑马消息队列-rabbitMQ2-生产者重连机制-生产者确认机制-数据持久化-LazyQueue-消费者确认机制-失败重试机制-重试耗尽告警手动处理-
java·缓存·中间件
闲人编程2 天前
中间件开发与生命周期管理
缓存·中间件·生命周期·日志·扩展·codecapsule
添加shujuqudong1如果未回复3 天前
用蜣螂优化(DBO)算法攻克置换流水车间调度问题
中间件
写代码的小阿帆3 天前
消息队列中间件RabbitMQ基础——Spring AMQP、路由模型到可靠性
中间件·rabbitmq·java-rabbitmq
sugar椰子皮5 天前
【爬虫框架-6】中间件的另一种写法实现
爬虫·中间件
天海行者5 天前
多数据源 + ShardingSphere 分库分表 + 读写分离 实现方案
中间件·shardingsphere·dynamic