为了避免服务器宕机而导致消息丢失,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的名称 |