erlang rabbitmq-server安装c++
yum -y install xsltproc fop tk unixODBC unixODBC-devel make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel服务器
yum –y install erlangcookie
yum –y install rabbitmq-serverapp
服务器集群信息,确保节点之间主机名能够相互解析。3d
172.16.230.166 masterunix
172.16.230.167 slave1server
172.16.230.168 slave2blog
172.16.230.16六、16七、168 启动rabbitmq进程rabbitmq
/etc/init.d/rabbitmq-server start进程
Rabbitmq的集群是依赖于erlang的集群来工做的,因此必须先构建起erlang的集群环境。Erlang的集群中各节点是经过一个magic cookie来实现的,这个cookie存放在$HOME/.Erlang.cookie 中,文件是400的权限。因此必须保证各节点cookie保持一致,不然节点之间就没法通讯。
[root@master ~]# cd /var/lib/rabbitmq/
[root@master ~]# tar -zcvf erlang.cookie.tar.gz .erlang.cookie
[root@master ~]#scp erlang.cookie.tar.gz 172.16.230.167:/var/lib/rabbitmq/
[root@master ~]#scp erlang.cookie.tar.gz 172.16.230.168:/var/lib/rabbitmq/
[root@slave1 ~]# cd /var/lib/rabbitmq/; tar –zxvf erlang.cookie.tar.gz
[root@slave2 ~]# cd /var/lib/rabbitmq/; tar –zxvf erlang.cookie.tar.gz
前期准备工做已经完成,下面就来开始rabbitmq集群的配置,有了erliang的集群环境,rabbitmq集群环境构建起来很简单,只须要把其余节点添加到一台节点中便可,这里采用将slave1 添加到master中 ,slave2添加到slave1上的方法。
集群中有两种节点:
1 内存节点:只保存状态到内存(一个例外的状况是:持久的queue的持久内容将被保存到disk)
2 磁盘节点:保存状态到内存和磁盘。
[root@master ~]# rabbitmq-server –detached
[root@slave1 ~]# rabbitmq-server –detached
[root@slave2 ~]# rabbitmq-server –detached
[root@master ~]# rabbitmqctl cluster_status
[root@slave1 ~]# rabbitmqctl cluster_status
[root@slave2 ~]# rabbitmqctl cluster_status
[root@slave1 ~]# rabbitmqctl stop_app #关闭本机集群节点
[root@slave1 ~]# rabbitmqctl reset #从新设置
[root@slave1 ~]# rabbitmqctl join_cluster –ram rabbit@master
[root@slave1 ~]# rabbitmqctl stop_app
查看集群状态
[root@master ~]# rabbitmqctl cluster_status
[root@slave1 ~]# rabbitmqctl cluster_status
Slave2 加入到slave1
[root@slave2~]# rabbitmqctl stop_app #关闭本机集群节点
[root@slave2 ~]# rabbitmqctl reset #从新设置
[root@slave2 ~]# rabbitmqctl join_cluster –ram rabbit@master
[root@slave2~]# rabbitmqctl stop_app
查看集群状态
[root@master ~]# rabbitmqctl cluster_status
[root@slave1 ~]# rabbitmqctl cluster_status
[root@slave2 ~]# rabbitmqctl cluster_status
[root@master~]# rabbitmqctl stop_app #关闭本机集群节点
[root@ master ~]# rabbitmqctl reset #从新设置
izhhhi[root@ master ~]# rabbitmqctl start_app