activemq简单配置数据库高可用

本文介绍了如何通过jdbc实现ActiveMQ的高可用配置。主要步骤包括:设置mq的jdbc高可用,复制并修改配置文件以更改端口,启动两个mq实例,并关注启动后的日志错误。值得注意的是,避免在配置中使用useDatabaseLock="false",以免导致队列状态不同步。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、activemq可以使用jdbc高可用配置,且配置简单

vim conf/activemq.xml

#修改 <borker> 节点的 brokerName 属性,新加入 persistent 属性。
<broker xmlns="http://activemq.apache.org/schema/core" brokerName="127.0.0.1" persistent="true" dataDirectory="${activemq.data}">

# <persistenceAdapter> 节点下面配置如下代码,将默认的<kahaDB directory="${activemq.data}/kahadb"/>注释
<persistenceAdapter>
    <jdbcPersistenceAdapter dataDirectory="${activemq.base}/activemq-data" dataSource="#mysql-ds"/>
</persistenceAdapter>

#在 <broker> 节点外面新增如下内容
<!-- MySql DataSource Master Slave -->
<bean id="mysql-ds" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost/activemq?relaxAutoCommit=true"/>
    <property name="username" value="activemq"/>
    <property name="password" value="activemq"/>
    <property name="poolPreparedStatements" value="true"/>
</bean>

2、复制整个mq文件夹,重命名,若同一台机器则改一下<transportConnector name="openwire" uri="tcp://0.0.0.0:61616?maximumConnections=1000&amp;wireFormat.maxFrameSize=10485760000"/>中的61616端口以及jetty.xml里面的8161端口,若不同机器可以不改。

    <bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">
             <!-- the default port number for the web console -->
        <property name="host" value="0.0.0.0"/>
        <property name="port" value="8161"/>
    </bean>

3、依次启动两个mq,程序使用url为以下,ip端口自行修改

failover:(tcp://192.168.1.100:61616,tcp://192.168.1.101:61616)

注意:后启动的mq的data文件夹下日志文件会报以下错误,且该mq的控制台界面是打不开的,这是正常的,是因为后启动的没争夺到数据库的锁,当主节点关闭时程序会自动连接从节点,且锁会自动放开被从节点获取,此时控制台也能打开了

| INFO  | Failed to acquire lock.  Sleeping for 10000 milli(s) before trying again... | org.apache.activemq.store.jdbc.DefaultDatabaseLocker | main

另外,若在jdbcPersistenceAdapter节点中添加useDatabaseLock="false",两个节点的控制台都能打开,但会导致一个问题,两个节点的队列状态信息就不会同步,所以若单纯使用jdbc-master-slave模式不要加此节点。

 

部分引用 : https://blog.youkuaiyun.com/xiaoxing598/article/details/51604999

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lin245709189

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值