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&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