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:存储订阅关系。

字段类型描述
CONTAINERvarchar消息的Destination
SUB_DESTvarchar如果是使用static集群,则会有集群其他系统的信息
CLIENT_IDvarchar每个订阅者的客户端ID
SUB_NAMEvarchar订阅者名称
SELECTORvarchar选择器,可以选择只消费满足条件的消息
LAST_ACKED_IDbigint最后一次确认ID,该订阅者最后一次收到的消息的ID
PRIORITYbigint优先级,值越大优先级越高
XIDvarchar

activemq_msgs:存储消息。

字段类型描述
IDbigint主键ID
CONTAINERvarchar消息的Destination
MSGID_PRODvarchar消息发送者客户端的主键
MSGID_SEQbigint发送消息的顺序,MSGID_PROD+MSG_SEQ可以组成JMS的MessageID
EXPIRATIONbigint消息的过期时间,存储的是从1970-01-01到现在的毫秒数
MSGlongblob消息内容
PRIORITYbigint优先级,值越大优先级越高
XIDvarchar

activemq_lock:存储锁信息。

字段类型描述
IDbigint主键ID
TIMEbigint时间
BROKER_NAMEvarchar拥有锁的Broker的名称
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值