activeMQ集群的安装


1.解压


tar zxvf apache-activemq-5.13.3-bin.tar.gz


2.移动解压目录分别生成不同的节点


cp -r apache-activemq-5.13.3 /usr/local/ActiveMQ-node1


cp -r apache-activemq-5.13.3 /usr/local/ActiveMQ-node2


cp -r apache-activemq-5.13.3 /usr/local/ActiveMQ-node3



3,修改每一个节点的注册方式为zookeeper (注意是每一个节点)


 vim /usr/local/ActiveMQ-node1/conf/activemq.xml


 注释一下信息:


           <!--

 #81         <persistenceAdapter>

 #82             <kahaDB directory="${activemq.data}/kahadb"/>

 #83         </persistenceAdapter>

           -->


 添加如下内容:



         <persistenceAdapter>

           <replicatedLevelDB

             directory="${activemq.data}/leveldb"

             replicas="3"

             bind="tcp://0.0.0.0:0"

             zkAddress="192.168.31.66:2181,192.168.31.66:2182,192.168.31.66:2183"

             hostname="192.168.31.66"

             sync="local_disk"

             zkPath="/activemq/leveldb-stores"/>

         </persistenceAdapter>

================================================================================================

说明:        

 <persistenceAdapter>

           <replicatedLevelDB

             directory="${activemq.data}/leveldb"   

             replicas="3"             节点数

             bind="tcp://0.0.0.0:0"   对外所有ip提供服务

             zkAddress="192.168.31.66:2181,192.168.31.66:2182,192.168.31.66:2183"  向zookeeper上注册的ip和监听的端口

             hostname="192.168.31.66"    本机的ip

             sync="local_disk"     存储数据为本地硬盘

             zkPath="/activemq/leveldb-stores"/>

         </persistenceAdapter>

================================================================================================


4.修改每一个节点的监听端口


修改每一个实例的监听端口,修改openwire的值,一个实例端口分别为61616,61617,61618


vim /usr/local/ActiveMQ-node1/conf/activemq.xml



        <transportConnectors>

            <!-- DOS protection, limit concurrent connections to 1000 and frame size to 100MB -->

            <transportConnector name="openwire" uri="tcp://0.0.0.0:61617?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>

            <transportConnector name="amqp" uri="amqp://0.0.0.0:5672?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>

            <transportConnector name="stomp" uri="stomp://0.0.0.0:61613?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>

            <transportConnector name="mqtt" uri="mqtt://0.0.0.0:1883?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>

            <transportConnector name="ws" uri="ws://0.0.0.0:61614?maximumConnections=1000&amp;wireFormat.maxFrameSize=104857600"/>

        </transportConnectors>


5.如果在一台物理机上做三个节点,必须修改节点的默认管理端口,否侧端口占用


vim /usr/local/ActiveMQ-node1/conf/jetty.xml 


#115         <property name="port" value="8162"/>        默认为8161



6.分别启动,关闭三个节点,查看三个节点的状态



/usr/local/ActiveMQ-node1/bin/activemq start/status/stop



7.将集群节点添加为系统服务并设为开机自启


  节点一


 vim /etc/init.d/activemq-node1


#!/bin/sh

# activemq

# chkconfig: 345 63 37

# description: activemq-node1

. /etc/rc.d/init.d/functions

. /etc/sysconfig/network

case $1 in

start)

sh /usr/local/activeMQ-node1/bin/activemq start

;;

stop)

sh /usr/local/activeMQ-node1/bin/activemq stop

;;

status)

sh /usr/local/activeMQ-node1/bin/activemq status

;;

restart)

sh /usr/local/activeMQ-node1/bin/activemq stop

sh /usr/local/activeMQ-node1/bin/activemq start

;;

esac

exit 0 


添加执行权限

  chmod +x /etc/init.d/activemq-node1


添加系统服务,设为开机自启


chkconfig --add activemq-node1

chkconfig activemq-node1 on


节点二,节点三类似如上,注意节点目录