zoukankan      html  css  js  c++  java
  • Centos7 离线安装RabbitMQ,并配置集群

    Centos7 离线安装RabbitMQ,并配置集群

    版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
    本文链接:https://blog.csdn.net/Alger_magic/article/details/82868267

    目的:Centos7 离线安装RabbitMQ,并配置集群

    环境:

    系统:Centos 7.5
    环境:
    
    • 1
    • 2

    一、安装RabbitMQ:

    1. 安装包及依赖下载,Rabbitmq安装主要依赖两个rpm, erlang和socat

    1. 下载erlang, 在https://packagecloud.io/rabbitmq/erlang页面选择对应版本的erlang的rpm安装包(centos7需要19.3以上版本。
      在这里插入图片描述

    2. 下载socat, 在http://www.rpmfind.net/linux/rpm2html/search.php?query=socat(x86-64)页面下载centos7版本的socat的rpm安装包。
      在这里插入图片描述

    3. 下载Rabbitmq, 在http://www.rabbitmq.com/install-rpm.html页面下载centos7版本的安装包
      在这里插入图片描述

    ps:也可以直接下载资源https://download.csdn.net/download/alger_magic/10716820

    2. rpm安装

    1. 将下载到的rpm文件copy入centos7,放置到自定义文件夹中。

    2. 使用rpm命令安装,也可以使用yum install *.rpm安装。
      sudo rpm -ivh erlang-19.3.6.11-2.el6.x86_64.rpm
      sudo rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
      sudo rpm -ivh rabbitmq-server-3.7.8-1.el7.noarch.rpm

      ps:
      在使用windows虚拟机安装的centos7,使用鼠标直接拖入rpm的方式copy进centos,在安装时可能提示包出错(猜测是copy过程中可能有缺失)。
      解决方法是使用winscp上传或者用u盘copy过去。
      在这里插入图片描述

    3. start rabbitmq

    1. 执行sudo service rabbitmq-server start
      提示如图所示则表示启动成功
      在这里插入图片描述

    2. 配置rabbitmq管理账户。
      执行命令 rabbitmqctl add_user admin admin,设置账户密码为admin admin
      在这里插入图片描述

    3. 执行命令 rabbitmqctl set_user_tags admin administrator,设置admin为管理员权限
      在这里插入图片描述

    4. 执行命令 rabbitmq-plugins enable rabbitmq_management,打开rabbitmq web管理。
      在这里插入图片描述

    5. 管理链接为:http://localhost:15672,登陆账户密码为设置的admin admin
      在这里插入图片描述

    6. 登陆管理端,并打开访问权限。
      a.登陆后台
      使用该用户登陆后台
      b.查看用户权限,默认状态下权限是不允许访问(此时程序访问5672端口是连接被拒绝)。查看用户权限,默认状态下权限是不允许访问
      c.点击用户名,进入用户页面,直接点击设置权限。此时刷新页面回到Users页面,权限变成可访问。
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述
      PS:常见问题
      一. http://ip:15672不能访问,确认两点:1. 添加用户、给用户设置管理员权限、rabbitmq-plugins这三步是否执行成功。2. 使用firewall打开5672/15672端口。具体步骤如下:

    sudo service firewalld start
    firewall-cmd --zone=public --add-port=5672/tcp --permanent
    firewall-cmd --zone=public --add-port=15672/tcp --permanent
    sudo service firewalld start(如果系统不要求开启防火墙,可以在设置完以后再关闭它)
    备注:即使防火墙处于关闭状态,也应该先打开端口再关闭,否则在有些机器上会仍然端口不通。
    

    二、RabbitMQ集群部署:

    1.按照前面的方式在想要集群的多台主机上安装好RabbitMQ实例

    2.集群配置

    1.更改主机/etc/hosts,加入主机节点。 如下所示三台主机均在/etc/hosts中添加,然后三台主机相互之间可以ping通rabbit-node

    vim /etc/hosts
    添加内容:
    192.168.1.201 rabbit-node1
    192.168.1.202 rabbit-node2
    192.168.1.203 rabbit-node3

    2. 由于RabbitMQ集群的主机需要使用同一个erlang.cookie。所以需要将多台主机的erlang.cookie设置为同一个。

    1. erlang.cookie位置: 如果是使用rpm包安装的rabbitmq, erlang.cookie的位置在/var/lib/rabbitmq/.erlang.cookie;如果是源码编译安装,erlang.cookie文件位置在~/.erlang.cookie

    2. 例如上面的三台主机操作流程如下:如果以rabbit-node1的erlang.cookie作为集群的erlang.cookie.

    1. 在node1的主机上 chmod 777 /var/lib/rabbitmq/.erlang.cookie.(改变只读权限,让node2,node3可以获取)
    2. 在node2主机上执行:
        chmod 777 /var/lib/rabbitmq/.erlang.cookie   
        scp -r rabbitmq-node1:/var/lib/rabbitmq/.erlang.cookie /var/lib/rabbitmq/.erlang.cookie
        输入yes
        输入node1的密码
        提示: .erlang.cookie  100%  20,即执行成功
    3. 同样在node3主机上执行:
        chmod 777 /var/lib/rabbitmq/.erlang.cookie   
        scp -r rabbitmq-node1:/var/lib/rabbitmq/.erlang.cookie /var/lib/rabbitmq/.erlang.cookie
        输入yes
        输入node1的密码
        提示: .erlang.cookie  100%  20,即执行成功
     4. 在三台主机上使用cat /var/lib/rabbitmq/.erlang.cookie查看erlang.cookie是否统一,如果已统一,再分别执行chmod 400 /var/lib/rabbitmq/.erlang.cookie,恢复原本权限
    
    

    3. 配置集群

    1. 在三台主机上停止当前Rabbitmq-server, 分别执行service rabbitmq-server stop,如有问题,可以使用ps查看rabbitmq进程号,在kill -9 杀掉。
    2. 然后执行service rabbitmq-server start 开启服务.
    3. 分别在三台主机上执行rabbitmqctl cluster_status查看集群状况,此时只有本机的记录。打印输出如下:
    Cluster status of node rabbit@ rabbit-node ...
    [{nodes,[{disc,[rabbit@ rabbit-node]}]},
     {running_nodes,[rabbit@ rabbit-node]},
     {cluster_name,<<"rabbit@ rabbit-node">>},
     {partitions,[]},
     {alarms,[{rabbit@ rabbit-node,[]}]}] 
    1. 将 rabbit-node1, rabbit-node2, rabbit-node3组成集群。
    1.在 rabbit-node2上执行:
        rabbitmqctl stop_app
        rabbitmqctl join_cluster rabbit@rabbit-node1
        rabbitmqctl start_app
    
    2.同样在 rabbit-node3上执行:
    	rabbitmqctl stop_app
    	rabbitmqctl join_cluster rabbit@rabbit-node1
    	rabbitmqctl start_app
    3.集群就建立完成了(rabbit-node2, rabbit-node3之间会自动建立连接)。
    4.在三台主机上分别执行rabbitmqctl cluster_status查看集群状态,结果如下:
    	Cluster status of node rabbit@rabbit-node1 ...
    	[{nodes,[{disc,['rabbit@rabbit-node1','rabbit-node2',
                  	  'rabbit@rabbit-node3']}]},
    	 {running_nodes,['rabbit@rabbit-node1','rabbit@rabbit-node2',
                    	 'rabbit@rabbit-node3']},
    	 {cluster_name,<<"rabbit@rmq-cluster-1">>},
    	 {partitions,[]},
    	 {alarms,[{'rabbit@rabbit-node1',[]},
    	          {'rabbit@rabbit-node2',[]},
    	          {'rabbit@rabbit-node3',[]}]}]
    表示集群创建成功,从任意一个节点的rabbitmq web管理端也可以看到各个节点状态
    

    如图:
    在这里插入图片描述

    三、为RabbitMQ安装配置负载均衡器HAProxy:

    1.下载安装

    1.下载地址http://www.rpmfind.net/linux/centos/7.5.1804/os/x86_64/Packages/haproxy-1.5.18-7.el7.x86_64.rpm
    2. 在集群以外的一台主机上安装HAProxy(如主机不足也可以安装在其中一台,示例安装在rabbit-node1), rpm -ivh haproxy-1.5.18-7.el7.x86_64.rpm.

    2. 配置负载均衡

    1. HAProxy程序的配置文件默认在/etc/haproxy/haproxy.cfg
    2. vim /etc/haproxy/haproxy.cfg,在末尾添加,如已有负载均衡配置,注释掉旧的配置

    ####################################################################
    listen http_front
            bind 0.0.0.0:8100           #监听端口  
            stats refresh 30s           #统计页面自动刷新时间  
            stats uri /haproxy?stats            #统计页面url  
            stats realm Haproxy Manager #统计页面密码框上提示文本  
            stats auth admin:admin      #统计页面用户名和密码设置  
            #stats hide-version         #隐藏统计页面上HAProxy的版本信息
    
    #####################我把RabbitMQ的管理界面也放在HAProxy后面了###############################
    listen rabbitmq_admin 
        bind 0.0.0.0:8101
        server node1 192.168.1.201:15672
        server node2 192.168.1.202:15672
        server node3 192.168.1.203:15672
    ####################################################################
    listen rabbitmq_cluster 
        bind 0.0.0.0:5671
        option tcplog
        mode tcp
        timeout client  3h
        timeout server  3h
        option          clitcpka
        balance roundrobin      #负载均衡算法(#banlance roundrobin 轮询,balance source 保存session值,支持static-rr,leastconn,first,uri等参数)
        #balance url_param userid
        #balance url_param session_id check_post 64
        #balance hdr(User-Agent)
        #balance hdr(host)
        #balance hdr(Host) use_domain_only
        #balance rdp-cookie
        #balance leastconn
        #balance source //ip
        server   node1 192.168.1.201:5672 check inter 5s rise 2 fall 3   #check inter 2000 是检测心跳频率,rise 2是2次正确认为服务器可用,fall 3是3次失败认为服务器不可用
        server   node2 192.168.1.202:5672 check inter 5s rise 2 fall 3
        server   node3 192.168.1.203:5672 check inter 5s rise 2 fall 3
    
    

    3. 重启HAProxy, sudo service haproxy restart
    4. 在浏览器输入http://rabbit-node1:8100/haproxy?stats, 查看HAProxy状态,如下图
    在这里插入图片描述

    5. 安装已完成,可使用HAProxy配置的端口(示例中5671)进行rabbitmq操作,测试负载均衡效果

    6、rabbitmq常用命令

        add_user        <UserName> <Password>

        delete_user    <UserName>

        change_password <UserName> <NewPassword>

        list_users

        add_vhost    <VHostPath>

        delete_vhost <VHostPath>

        list_vhostsset_permissions  [-p <VHostPath>] <UserName> <Regexp> <Regexp> <Regexp>

        clear_permissions [-p <VHostPath>] <UserName>

        list_permissions  [-p <VHostPath>]

        list_user_permissions <UserName>

        list_queues    [-p <VHostPath>] [<QueueInfoItem> ...]

        list_exchanges [-p <VHostPath>] [<ExchangeInfoItem> ...]

        list_bindings  [-p <VHostPath>]

        list_connections [<ConnectionInfoItem> ...]

  • 相关阅读:
    mac下的一个类似“_kbhit()”实现
    mac使用备注
    open()打开文件失败对应的各种错误码
    xcode显示行号show gutter
    下载google code中源码的几个工具
    HTML5迷你游戏作验证码
    Linux+eclipse+gdb调试postgresql源码
    S-Nim
    【求助】从大表中删除小表中存在的记录问题
    Binary Tree Zigzag Level Order Traversal (LeetCode) 层序遍历二叉树
  • 原文地址:https://www.cnblogs.com/mayhh/p/11425532.html
Copyright © 2011-2022 走看看