ActiveMQ 使用Mysql8.0.11进行持久化---踩坑日记

ActiveMQ中对于投递模式设置为持久化的消息,broker接收到到消息之后,会先把消息存储到存储介质,然后再转发到消息的监听者。

ActiveMQ使用mysql数据库进行消息持久化,具体操作步骤如下:

1、修改ActiveMQ的配置文件: conf/activemq.xml,找到<persistenceAdapter>这个配置项,

修改为如下内容:

<persistenceAdapter>
	<jdbcPersistenceAdapter useDatabaseLock="false" dataSource="#mysqlDs" createTablesOnStartup="true"  />
</persistenceAdapter>

 

2、在<broker>标签外创建对应的 id为mysqlDs的bean标签(使用高版本mysql时,以下配置会出错)

<bean id="mysqlDs" 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>

然后重新运行ActiveMQ,结果mq控制台输出如下错误:(问题分析,我使用的Mysql版本为8.0.11)

发现链接Mysql参数Url必须得加上Mysql高版本版本的一些特性参数,经过作者试错,发现需要添加的参数有以下:

serverTimezone:时区设置

useSSL:指明是否进行SSL连接

另外需要注意的是: xml中需要对一些特殊符号进行转义,最终正确的数据库配置信息如下:

<bean id="mysqlDs" 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&amp;serverTimezone=GMT%2B8" />
	<property name="username" value="root" />
	<property name="password" value="root" />
	<property name="poolPreparedStatements" value="true"/>
</bean>

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值