centos7.3 rabbitmq集群

  • 时间:
  • 浏览:0
  • 来源:uu快3开奖历史_uu快3玩法_注册

VORMVSAAOFOFEQKTNWBB

10

node1:

Cluster status of node rabbit@node3 ...

15

2

   '{"ha-mode":"exactly","ha-params":2,"ha-sync-mode":"automatic","ha-promote-on-shutdown":"always","ha-sync-batch-size":20}'

1

  RabbitMQ节点之间和命令行工具 (e.g. rabbitmqctl)是使用Cookie互通的,Cookie是一组随机的数字+字母的字符串。当RabbitMQ服务器启动的但是,Erlang VM会自动创建1个 多随机内容的Cookie文件。机会是通过yum源安装RabbitMQ句子,Erlang Cookie 文件在/var/lib/rabbitmq/.erlang.cookie。机会是通过源码安装的RabbitMQ,Erlang Cookie文件$HOME/.erlang.cookie。

19

yancongadmin@node1:~$ chmod 50 .erlang.cookie

10.0.0.233  node3

.erlang.cookie                                                                                     50%   20     0.0KB/s   00:00

11

7

8

node2:

5

类似于下面的命令,^message 這個 规则要根据某些人修改,這個 是指同步”message”开头的队列名称,亲戚亲戚朋友配置时使用的应用于所有队列,很多有表达式为”^”。

在任意1个 多节点上执行:

Stopping node rabbit@node3 ...

26

4

yancongadmin@node1's password:

yancongadmin@node3:~$ rabbitmqctl stop_app

Stopping node rabbit@node2 ...

5

本文转自 yanconggod 51CTO博客,原文链接:http://blog.51cto.com/yanconggod/1933950

Starting node rabbit@node3 ...

13

Clustering node rabbit@node2 with rabbit@node1 ...

6

Clustering node rabbit@node3 with rabbit@node1 ...

Cluster status of node rabbit@node2 ...

这行命令在vhost名称为hrsystem创建了1个 多策略,策略名称为ha-allqueue,策略模式为 all 即克隆qq好友好友到所有节点,蕴藏新增节点,策略正则表达式为 “^” 表示所有匹配所有队列名称。

18

本文演示的实例是用源码安装,机会這個 文件权限是 50,很多有必须先修改 node2、node3 中的该文件权限为 777:

server   node3 10.0.0.233:5672 check inter 50 rise 2 fall 3

20

此时 node2 与 node3 也会自动建立连接。

node2:

7

yancongadmin@node2:~$ rabbitmqctl cluster_status

1

[{nodes,[{disc,[rabbit@node1,rabbit@node2,rabbit@node3]}]},

5

 {alarms,[{rabbit@node3,[]}]}]

http://yanconggod.blog.51cto.com/1351649/193509

yancongadmin@node1:~$ rabbitmqctl stop

8

node2:

3

Cluster status of node rabbit@node3 ...

机会要使用内存节点,则能都能否使用以下命令:

1

11

15

1

2

1

3

 {alarms,[{rabbit@node2,[]}]}]

1

 {running_nodes,[rabbit@node3]},

17

yancongadmin@node2:~$ chmod 777 .erlang.cookie

15

yancongadmin@node1:~$ rabbitmqctl cluster_status

将所有队列设置为镜像队列,即队列会被克隆qq好友好友到各个节点,各个节点请况保持总爱。

13

4

3

使用detached参数,在后台启动Rabbit Node

14

12

4

10

13

1

 {running_nodes,[rabbit@node1]},

   '{"ha-mode":"exactly","ha-params":2,"ha-sync-mode":"automatic","ha-promote-on-shutdown":"always","ha-sync-batch-size":20}'

2

10.0.0.231  node1

22

 {cluster_name,<<"rabbit@node1">>},

3

11

9

5

yancongadmin@node1's password:

2

server   node1 10.0.0.231:5672 check inter 50 rise 2 fall 3 

node1:

2

 {running_nodes,[rabbit@node1]},

8

9

1

rabbitmqctl set_policy ha-xxx "^cn\.xxx" \

Starting node rabbit@node2 ...

3

15

mode tcp

3

rabbitmqctl set_policy queue-xxx "^queue" \

     通过 Erlang 的分布式实物(通过 magic cookie 认证节点)进行 RabbitMQ 集群,各 RabbitMQ 服务为对等节点,即每个节点都提供服务给客户端连接,进行消息发送与接收。

yancongadmin@node3:~$ scp -r node1:/home/yancongadmin/.erlang.cookie ~/

3

11

2

server   node2 10.0.0.232:5672 check inter 50 rise 2 fall 3

 {running_nodes,[rabbit@node2]},

16

参考:http://idoall.org/blog/post/lion/15

6

5

分别在node1、node2、node3将权限恢复过来:

yancongadmin@node3:~$ rabbitmqctl start_app

23

7

10

12

1

yancongadmin@node3:~$ rabbitmqctl cluster_status

安装 Erlang、RabbitMQ

4

[{nodes,[{disc,[rabbit@node1,rabbit@node2]}]},{alarms,[{rabbit@node1,[]}]}]

yancongadmin@node1:~$ rabbitmq-server -detached

9

yancongadmin@node2:~$ cat .erlang.cookie

2

yancongadmin@node2:

4

4

 {partitions,[]},

3

VORMVSAAOFOFEQKTNWBB

node3:

18

Cluster status of node rabbit@node1 ...

机会必须负载均衡器,必须安装并配置 HAProxy

6

Gracefully halting Erlang VM

1

yancongadmin@node1:~$ chmod 777 .erlang.cookie

9

yancongadmin@node3:~$ rabbitmqctl cluster_status

 {alarms,[{rabbit@node1,[]}]}]

13

balance roundrobin

使用Rabbit镜像功能,必须基于RabbitMQ策略来实现,策略是用来控制和修改群集范围的某个vhost队列行为和Exchange行为

yancongadmin@node2:~$ rabbitmqctl join_cluster --ram rabbit@node1

node3:

14

node2:

yancongadmin@node2:~$ rabbitmqctl set_policy -p hrsystem ha-allqueue"^" '{"ha-mode":"all"}'

8

node1:

Setting policy "ha-all" for pattern "^" to "{\"ha-mode\":\"all\"}" with priority "0"

 {alarms,[{rabbit@node1,[]}]}]

集群配置好后,能都能否在 RabbitMQ 任意节点上执行 rabbitmqctl cluster_status 来查看是是不是集群配置成功。

yancongadmin@node3:~$ cat .erlang.cookie

yancongadmin@node1:~$ rabbitmqctl cluster_status

     什么节点通过 RabbitMQ HA 队列(镜像队列)进行消息队列实物克隆qq好友好友。本方案中搭建 3 个节点,有但是后会磁盘节点(所有节点请况保持一致,节点删改对等),假如有一天有任何1个 多节点都能否工作,RabbitMQ 集群对外就能提供服务。

5

25

node3:

Cluster status of node rabbit@node2 ...

7

1

1

将node1、node2、node3组成集群

 {partitions,[]},

yancongadmin@node2:~$ rabbitmqctl join_cluster rabbit@node1

[{nodes,[{disc,[rabbit@node1,rabbit@node2,rabbit@node3]}]},

我使用过的例子,仅供参考:

20

14

Cluster status of node rabbit@node1 ...

17

VORMVSAAOFOFEQKTNWBB

yancongadmin@node2:~$ scp -r node1:/home/yancongadmin/.erlang.cookie ~/

2

listen rabbitmq_cluster 0.0.0.0:5672

 {alarms,[{rabbit@node1,[]}]}]

10

类似于:

7

最后分别在确认三台机器上的.erlang.cookie的值是一致的

6

机会rabbitmq-server启动时,会同時 启动节点和应用,它预先设置RabbitMQ应用为standalone模式。要将1个 多节点加入到现有的集群中,你必须停止這個 应用并将节点设置为原始请况,有但是就为加入集群准备好了。机会使用./rabbitmqctl stop,应用和节点都将被关闭。很多有使用rabbitmqctl stop_app仅仅关闭应用。 

 {cluster_name,<<"rabbit@node1">>},

[{nodes,[{disc,[rabbit@node2]}]},

2

16

4

19

yancongadmin@node1:~$ cat .erlang.cookie

27

21

10.0.0.232  node2

24

1

4

14

yancongadmin@node2:~$ rabbitmqctl set_policy -p hrsystem ha-allqueue "^message" '{"ha-mode":"all"}'

[{nodes,[{disc,[rabbit@node3]}]},

加入集群 3 个节点的对应关系:

[{nodes,[{disc,[rabbit@node1]}]},

16

8

6

 {cluster_name,<<"rabbit@node3">>},

.erlang.cookie                                                                                     50%   20     0.0KB/s   00:00

node3:

5

 {partitions,[]},

RabbitMQ镜像功能

设置 Erlang Cookie

通过rabbitmqctl cluster_status命令,能都能否查看和个节点的请况,节点的名称是rabbit@shorthostname,

12

12

 {partitions,[]},

yancongadmin@node2:~$ rabbitmqctl cluster_status

yancongadmin@node2:~$ rabbitmqctl stop_app

yancongadmin@node3:~$ chmod 777 .erlang.cookie

yancongadmin@node2:~$ rabbitmqctl start_app

RabbitMQ集群概述

6

修改 /etc/hosts

 {cluster_name,<<"rabbit@node2">>},

Stopping and halting node rabbit@node1 ...

yancongadmin@node3:~$ rabbitmqctl join_cluster rabbit@node1