zoukankan      html  css  js  c++  java
  • rabbitmq集群搭建,镜像队列搭建

    原文地址:https://www.jianshu.com/p/11963564dd3d

    教你如何从0开始搭建rabbitmq集群

    一、准备工作

    1、三台centos虚拟机
    2、三台虚拟机都安装了docker
    3、假设三台虚拟机的ip是192.168.2.128,192.168.2.129,192.168.2.130

    二、搭建rabbitmq集群

    1、3台机子分别配置host文件

    vim /etc/hosts
    填入内容:
    192.168.2.128 rabbit1
    192.168.2.129 rabbit2
    192.168.2.130 rabbit3
    host文件

    2、运行rabbit容器

    在rabbit1机器运行
    docker run -d --hostname rabbit1 --net=host --name myrabbit1 -p 4369:4369 -p 15672:15672 -p 5672:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' rabbitmq:3.6.15-management
    在rabbit2机器运行
    docker run -d --hostname rabbit2 --net=host --name myrabbit2 -p 4369:4369 -p 15672:15672 -p 5672:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' rabbitmq:3.6.15-management
    在rabbit3机器运行
    docker run -d --hostname rabbit3 --net=host --name myrabbit3 -p 4369:4369 -p 15672:15672 -p 5672:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' rabbitmq:3.6.15-management

    3、加入集群

    在rabbit2机器执行命令

    rabbitmqctl stop_app 
    rabbitmqctl reset
    rabbitmqctl join_cluster rabbit@rabbit1
    rabbitmqctl start_app
    exit
    

    在rabbit3机器执行命令

    rabbitmqctl stop_app 
    rabbitmqctl reset
    rabbitmqctl join_cluster rabbit@rabbit1
    rabbitmqctl start_app
    exit
    

    进入 192.168.2.130:15672 查看状态账号密码是guest/guest
    rabbitmq集群

    如果要摘除节点,在rabbit1机器执行:
    docker exec -it myrabbit1 bash
    rabbitmqctl forget_cluster_node rabbit@rabbit3
    exit

    点击queues,填写队列名,然后新增一个队列
    新增队列
    此时队列内容没冗余,只存在rabbit1中,当rabbit1的队列服务挂了,此队列也不可用了。
    在rabbit1机器执行
    docker stop myrabbit1

    再查看管理台
    管理台
    队列

    三、创建镜像队列

    重新启动rabbit1
    docker start myrabbit1
    新建2个队列extqueue和nodesqueue
    新建队列

    rabbitmqctl set_policy [-p ] [--priority ] [--apply-to ]

    指令参数详情
    参数名称 描述
    -p 可选参数,针对指定 vhost 下的exchange或 queue
    --priority 可选参数,policy 的优先级
    --apply-to 可选参数,策略适用的对象类型,其值可为 "queues", "exchanges" 或 "all".默认是"all"
    name policy 的名称
    pattern 匹配模式(正则表达式)
    definition 镜像定义,json 格式,包括三部分(ha-mode,ha-params,ha-sync-mode)具体配置见下表
    definition参数详情

    参数名称 描述
    ha-mode 指名镜像队列模式,其值可为"all","exactly"或"nodes",all:表示在集群所有节点上进行镜像;exactly:表示在指定个数的节点上镜像,节点个数由 ha-params 指定;nodes:表示在指定节点上进行镜像,节点名称通过ha-params 指定。
    ha-params ha-mode模式需要用到的参数:exactly 模式下为数字表述镜像节点数,nodes 模式下为节点列表表示需要镜像的节点。
    ha-sync-mode 镜像队列中消息的同步方式,其值可为"automatic"或"manually".

    例子:要对规则是^ext*的队列增加镜像队列,一共是2个队列
    docker exec -it myrabbit1 bash
    rabbitmqctl set_policy --apply-to queues extpolicy "^ext*" '{"ha-mode":"exactly","ha-params":2,"ha-sync-mode":"automatic"}'
    exit

    例子:要对规则是^nodes*的队列增加镜像队列,分别在rabbit@rabbit2和rabbit@rabbit3两台服务器上镜像
    docker exec -it myrabbit1 bash
    rabbitmqctl set_policy --apply-to queues nodespolicy "^nodes*" '{"ha-mode":"nodes","ha-params":["rabbit@rabbit2","rabbit@rabbit3"],"ha-sync-mode":"automatic"}'
    exit

    linux命令

    效果

    extqueue
    可以看到都匹配到对应的规则,有1个冗余的队列。
    此时我们把rabbit2停掉看一看效果;
    在rabbit2的机器上执行
    docker stop myrabbit2
    集群全集
    nodesqueue
    nodesqueue队列依旧工作
    extqueue
    extqueue队列的镜像队列换了一个。

  • 相关阅读:
    我倾向于使用发布版本进行调试,而不是使用调试版本
    常见WinDbg问题及解决方案
    在崩溃转储中查找所有可能的上下文记录
    向C/C++程序员介绍Windbg 脚本
    VS 使用技巧(1)
    Windows资源监视器软件的原理
    微架构、指令集架构与汇编语言的关系
    调试寄存器 原理与使用:DR0-DR7
    如何学习调试?
    WinDbg: 执行 SOS 扩展命令 !clrstack时报错 Access violation exception (0xC0000005)
  • 原文地址:https://www.cnblogs.com/yeyongjian/p/13234354.html
Copyright © 2011-2022 走看看