activemq leveldb切换jdbc主从模式

之前一直在用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 不然只有队列没有消息是不能持久化的 点击发送

 

之后尝试切换主从,如果发现消息都在的话表示成功 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值