centos 6.5 rabbitmq 安装和集群,镜像部署

安装erlang:

yum install gcc glibc-devel make ncurses-devel openssl-devel xmlto

wget http://erlang.org/download/otp_src_20.2.tar.gz

tar -zxvf otp_src_20.2.tar.gz
cd otp_src_20.2
./configure --prefix=/data/soft/erlang
make && make install # 添加环境变量:
export PATH=$PATH:/data/soft/erlang/bin

安装rabbitmq:

wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.1/rabbitmq-server-generic-unix-3.6.1.tar.xz
xz -d rabbitmq-server-generic-unix-3.6.1.tar.xz
tar -xvf rabbitmq-server-generic-unix-3.6.1.tar mv rabbitmq_server-3.6.1 /data/soft/rabbitmq # 启动:
./rabbitmq-server -detached # 关闭:
./rabbitmqctl stop # 配置网页插件:
mkdir /etc/rabbitmq
./rabbitmq-plugins enable rabbitmq_management 默认账号:guest 密码:guest
*** 默认账号和密码无法登陆,下面的操作是创建一个可以登陆的账号。
# web 网页登陆:
http:IP:15672/ 回车 ## 创建一个账号 admin 密码是admin:
rabbitmqctl add_user admin admin ## 给admin 赋予权限:
rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*" ## 给admin 赋予新的身份:
rabbitmqctl set_user_tags admin administrator ## 给admin 更改密码:
rabbitmqctl change_password admin xianlife.com ### 配置文件:
git clone https://github.com/rabbitmq/rabbitmq-server.git

镜像集群配置:

RABBITMQ搭建集群
环境:有二台主机,主机名和IP如下,rabbitmq的执行用户为rabbitmq,所属组为rabbitmq。 IP 主机名
10.81.35.124 rabbitmq-m
10.81.35.119 rabbitmq-s 同步erlang.cookie
杀掉rabbitmq-s 的rabbitmq进程: ps –ef|grep rab|awk ‘{print $2}’|xargs kill -9。–用service rabbitmq-servier stop停会有遗留进程。 登陆rabbitmq-m(rabbitmq-m上的rabbitmq服务不能关),执行 cd /root/ –进入erlang.cookie所在目录,只有ls –al能看见此文件 chmod 777 .erlang* –该文件默认为400权限,为方便传输,先修改权限,非必须操作 scp .erlang.cookie rabbitmq@10.81.35.119:/root/ –将此文件传给另外两条主机 chmod 400 .er* –恢复文件权限 分别在rabbitmq-s 上执行 chown rabbitmq:rabbitmq .er* –修改文件所属用户和所属组 chmod 400 .er* –修改文件权限 service rabbitmq-server start # 加入集群 ## 查询rabbitmq-m节点名称 rabbitmqctl cluster_status Cluster status of node rabbit@rabbitmq-m … [{nodes,[{disc,[rabbit@rabbitmq-m]}]},{running_nodes,[rabbit@ rabbitmq-m]}] …done. ### rabbitmq-s 加入rabbitmq-m 节点. #关掉rabbitmq-s服务
rabbitmqctl stop_app #rabbitmq-s加入rabbitmq-m, rabbitmq-s必须能通过rabbitmq-m的主机名ping通rabbitmq-m。
rabbitmqctl join_cluster rabbit@rabbitmq-m #启动rabbitmq2服务
rabbitmqctl start_app 查看集群信息
#此时里面就应该能看见其他的多个节点。集群名字为rabbit@rabbitmq。
rabbitmqctl cluster_status 用相同的方法把rabbitmq3 或者其他rabbitmq 主机也加入rabbitmq-m。

更改节点属性:

# –停止rabbitmq服务
rabbitmqctl stop_app # –更改节点为磁盘或内存节点
rabbitmqctl change_cluster_node_type disc/ram # –开启rabbitmq服务
rabbitmqctl start_app # 查看状态:
1 master 上管理页面看
2 rabbitmqctl cluster_status 命令查看 [root@rabbitmq-m rabbitmq]# rabbitmqctl cluster_status
Cluster status of node 'rabbit@rabbitmq-m' ...
[{nodes,[{disc,['rabbit@rabbitmq-m']},{ram,['rabbit@rabbitmq-s']}]},
{running_nodes,['rabbit@rabbitmq-s','rabbit@rabbitmq-m']},
{cluster_name,<<"rabbit@rabbitmq-m">>},
{partitions,[]},
{alarms,[{'rabbit@rabbitmq-s',[]},{'rabbit@rabbitmq-m',[]}]}]
[root@rabbitmq-m rabbitmq]#

创建测试queue:

rabbitmqctl eval 'rabbit_exchange:declare({resource, <<"/">>, exchange, <<"test-topic">>}, topic, true, false, false, []).'

rabbitmqctl eval 'rabbit_amqqueue:declare({resource, <<"/">>, queue, <<"test-queue">>}, true, false, [], none).'

rabbitmqctl eval 'rabbit_binding:add({binding, {resource, <<"/">>, exchange, <<"test-topic">>}, <<"*.com.cn">>, {resource, <<"/">>, queue, <<"test-queue">>}, []}).'

这三条命令执行后的最终结果是:在 / 虚拟主机下创建了topic类型的,持久化的,名为 test-topic的exchange,创建了持久化的,名为 test-queue 的queue,该队列以 *.com.cn 的routing key绑定到了 test-topic这个exchange上。

1  web页面查看是否创建成功。
2 查看从机器的queue 是否同步信息。

使用发现的问题

1   rabbitmq
1.1 hosts 要写主机名和IP的对应关系进去。
1.2 DNS 解析要能解析到rabbitmq-m 的对应ip,否则从启动会很慢,因为要去连接mq的主机,一直找不到就会等到超时。 2 rabbitmq cluster_status
2.1 mq全都挂了,一定是最后退出的,先启动.
2.2 如果主挂了而从还在运行的状况。
2.2.1 等最后退出的mq起来,其他的启动后自动连接cluster。
2.2.2 加入其它的mq-m。 需要确定master 是哪台,如果最后退出的自动升级成 master。

Centos 6.5 Rabbitmq 安装和集群,镜像部署的更多相关文章

  1. RabbitMQ安装、集群搭建、概念解析

    RabbitMQ安装.集群搭建.概念解析 基本概念 为什么会产生MQ 1.解耦:采用异步方式实现业务需求达到解耦的目的. 2.缓冲流量,削峰填谷: 问:为什么会有流量冲击? 答:采用"直接调 ...

  2. kubernetes学习与实践篇(二) kubernetes1.5 的安装和集群环境部署

    kubernetes 1.5 的安装和集群环境部署 文章转载自:http://www.cnblogs.com/tynia/p/k8s-cluster.html 简介: Docker:是一个开源的应用容 ...

  3. rabbitmq安装、集群搭建

    rabbitmq的安装: CentOS上面部署: 首先修改hosts文件 修改hosts文件vi /etc/hosts1.1.1.1 hostname 2.2.2.2 hostname 3.3.3.3 ...

  4. RabbitMQ安装以及集群部署

    本次记录安装RabbitMQ的过程,只针对MAC下单机版安装.单机集群安装方法以及配置haproxy负载均衡. RabbitMQ单机版本安装 RabbitMQ单机集群安装方法(适合开发练习) Rabb ...

  5. RabbitMQ学习之集群镜像模式配置

    1.增加负载均衡器 关于负载均衡器,商业的比如F5的BIG-IP,Radware的AppDirector,是硬件架构的产品,可以实现很高的处理能力.但这些产品昂贵的价格会让人止步,所以我们还有软件负载 ...

  6. Blazor+Dapr+K8s微服务之基于WSL安装K8s集群并部署微服务

         前面文章已经演示过,将我们的示例微服务程序DaprTest1部署到k8s上并运行.当时用的k8s是Docker for desktop 自带的k8s,只要在Docker for deskto ...

  7. rabbitMQ 安装,集群搭建, 编码

    RabbitMQ 一.背景 命令行工具: http://www.rabbitmq.com/man/rabbitmqctl.1.man.html 介绍入门文章: http://blog.csdn.net ...

  8. Rabbitmq安装、集群与高可用配置

    历史: RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现.AMQP 的出现其实也是应了广大人民群众的需求,虽然在同步消息通讯的世界里有很多 ...

  9. kubernetes 1.3 的安装和集群环境部署

    简介: Docker:是一个开源的应用容器引擎,可以为应用创建一个轻量级的.可移植的.自给自足的容器. Kubernetes:由Google开源的Docker容器集群管理系统,为容器化的应用提供资源调 ...

随机推荐

  1. Java并发编程的艺术(十)——线程池

    线程池的作用 降低资源消耗.重复利用已有线程,减少线程的创建和销毁造成的消耗. 提高响应速度.当有任务需要处理的时候,就不用再花费重新创建线程的时间了. 提高线程的可管理性.不合理利用线程,会浪费资源 ...

  2. mysql 基础入门 单表查询

    单表查询 select 表头,表头 as 别名 ,表头(+-*/的运算) from table_a 1.条件查询 where + 条件 <> , != 不等于 = 等于,也可以表示字符串值 ...

  3. 2020-2021-1 20209307《Linux内核原理与分析》第三周作业

    一.计算机的三大法宝 存储程序计算机.函数调用堆栈机制.中断机制 二.堆栈 堆栈的作用:记录函数调用框架.传递函数参数.保存返回值的地址.提供局部变量存储空间 堆栈操作:push栈顶地址减少四个字节. ...

  4. SpringBoot执行原理

    目录 [Toc] 一.执行原理: 每个Spring Boot项目都有一个主程序启动类,在主程序启动类中有一个启动项目的main()方法, 在该方法中通过执行SpringApplication.run( ...

  5. HCIP----静态实验

    要求: 1.全网可达 2.拓扑中所需地址全部基于192.168.0.0/24划分所得 3.使用静态路由 4.R1有三个环回,需要汇总 5.PC1与PC3属于同一VLAN,PC2和PC4属于同一VLAN ...

  6. 【进程/作业管理】篇章四:Linux任务计划、周期性任务执行

    命令归纳: at 未来时间点让特定任务运行一次 batch 未来时间点让系统自行选择在系统资源较空闲的时间去执行指定的任务 corn 周期性任务计划(corntad) at命令详解 <--- 假 ...

  7. 每日CSS_纯CSS制作进度条

    每日CSS_纯CSS制作进度条 2020_12_26 源码 1. 代码解析 1.1 html 代码解析 设置整个容器 <div class="container"> . ...

  8. MySQL建立索引遵循原则的注意点

    1.选择唯一性索引 唯一性索引的数据是唯一的,可以更快的通过该索引查询某条数据. 2.为经常需要排序,分组和联合操作的字段建立索引 order by,group by的字段在排序操作时很是耗时,可以对 ...

  9. ConstraintLayout 学习笔记

    如何阅读 xml 属性 与 Relativelayout 不同,ConstrainLayout 的属性需要同时说明需要怎么操作自己与目标控件,例如:layout_constraintLeft_toLe ...

  10. 【代码周边】npm是What?

    社区 程序员自古以来就有社区文化: 社区的意思是:拥有共同职业或兴趣的人们,自发组织在一起,通过分享信息和资源进行合作.虚拟社区的参与者经常会在线讨论相关话题,或访问某些网站.前端程序员也有社区,世界 ...