activemq的jdbc master/slave模式,基于mysql数据库java
一、添加数据源,在apache-activemq-5.11.1-1和apache-activemq-5.11.1-2的activemq.xml文件</broker>标签以后添加以下内容mysql
<!--mysql jdbc ms--> <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://localhost:3306/amq?relaxAutoCommit=true"/> <property name="username" value="root"/> <property name="password" value="123456"/> <property name="maxActive" value="200"/> <property name="poolPreparedStatements" value="true"/> </bean>
二、修改持久化配置,找到persistenceAdapter修改以下内容(amq1和amq2的配置文件activemq.xml)sql
<persistenceAdapter> <jdbcPersistenceAdapter dataDirectory="${activemq.data}" dataSource="#mysql-ds" createTablesOnStartup="false"/> </persistenceAdapter>
createTablesOnStartup="false" 在启动前不要配置,等集群启动过了,再配置。createTablesOnStartup是启动时建立表,只建立一次就够了。数据库
三、将mysql的驱动包mysql-connector-java-5.1.35.jar添加到amq各节点的lib目录下apache
四、小结
分布式
基于JDBC和基于共享文件系统的集群方案原理是一致的,只是把共享文件系统换成了共享数据库。测试
这种集群方式比共享文件系统方案更简单,更利于分布式部署,可是若是数据库失效,那么整个集群的节点随之所有失效。换言之,须要保证数据库的可靠性,好比采用数据库集群。url
五、测试访问
spa
http://localhost:8161/ 中止其中任何一台均可访问code