之前一直在用levedb持久化模式,LevelDB存储已被弃用,官方不再支持或建议使用,并且从 ActiveMQ 4.1 版本开始支持 JDBC 主从集群。
在mq进程启动时一个主(某一台mq进程)抓取数据库中表的独占锁,另一台mq进程会由于争抢不到表锁而阻塞,这样其它的进程都变成了从。(只允许有一个主,可以有多个从)
如果主的服务断开或者服务中断(比如进程中断、机器宕机等),它(原来的主)所占用的数据库表锁就会被释放,此时其他从开始竞争锁,谁先抢到谁就是新的主。
在原有的基础上修改persistenceAdapter配置
<persistenceAdapter>
<jdbcPersistenceAdapter dataSource="#mysql-ds" createTablesOnStartup="true" useDatabaseLock="false" />
</persistenceAdapter>
useDatabaseLock如果这个设置为false 那么所有节点都可以进行访问 这个模式的问题在于报错数据到数据库可能会出现主键冲突导致持久化数据失败
当设置为true是开启了独占模式,这个模式才是主从模式 也就是当主挂了之后 另外的节点才会启用对应的服务端口供客户端调用
createTablesOnStartup这个参数是启动的时候是否自动创建对应的表
这个参数适合在第一次数据库初始化的时候使用到初始化完成之后改回false
PS: 数据库需要设置编码为latin1 -- cp1252 West European
之后需要设置数据源,我所使用的是mysql
<bean id="mysql-ds" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://10.1.1.185:3306/activemq?relaxAutoCommit=true" />
<property name="username" value="***" />
<property name="password" value="****" />
<property name="initialSize" value="5" />
<property name="maxIdle" value="30" />
<property name="minIdle" value="1" />
<property name="poolPreparedStatements" value="true"/>
</bean>
这里需要注意的是登录数据库的user以及密码以及url
之后需要下载连接mysql 所需要的jar包:mysql-connector-java-5.1.46.jar,commons-dbcp-1.4.jar,commons-pool-1.6.jar,commons-collections-3.2.2.jar
之后重启服务会自动生成对应的表
之后在web页面上模拟操作
直接在Queues里新建test队列
必须勾上Persistent Delivery 不然只有队列没有消息是不能持久化的 点击发送
之后尝试切换主从,如果发现消息都在的话表示成功