消息队列的使用 RabbitMQ (二): Windows 环境下集群的实现
一、RabbitMQ 集群的基本概念
一个 RabbitMQ 中间件(broker) 由一个或多个 erlang 节点组成,节点之间共享 用户名、虚拟目录、队列消息、运行参数 等, 这个 节点的集合被称为集群。
举例说明, A、B、C 三个节点同在一个集群中, 发布端向 A 节点发送消息, 消费者可在 B 或 C 接收到消息。消息被消费后被删除。这是最基础的集群模式,不涉及到消息的镜像(high availabilit)。
不足之处就是当接收消息的节点挂掉后, 其他节点无法取到该节点中未被消费的消息。若做消息持久化, 则在重新启动该节点后,未消费信息可被获取。 若未做消息持久化,则消息丢失。
二、集群的配置
1、配置 host
假设现有 A、B 两台机器,其配置如下
A
IP: 178.101.200.160
节点名: rabbit-A
B
IP:178.101.200.161
节点名: rabbit-B
上面所说的节点名,可在 rabbitmq mangement 界面中查看,也可以在命令行中查看。
进入RabbitMQ Management 管理界面,右下角 rabbit@3vjap-ysd-0 中的 3vjap-ysd-0 即为当前节点名。

下面开始配置 hosts:
在 A、B 的 hosts 文件中,绑定 IP 与 节点名, 如下:
178.101.20.160 rabbit-A
178.101.20.161 rabbit-B
2、配置环境变量文件 rabbitmq-env.conf
环境变量文件,定义了 rabbitmq 的日志文件、数据存储位置。
在目录 C:\Users\Administrator\AppData\Roaming\RabbitMQ 下创建 rabbitmq-env.conf 文件。
A 中 rabbitmq-env.conf 文件内容如下:
NODENAME=rabbit@rabbit-A
NODE_IP_ADDRESS=178.101.20.160
NODE_PORT=5672
RABBITMQ_MNESIA_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\db
RABBITMQ_LOG_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\log
B 中 rabbitmq-env.conf 文件内容如下:
NODENAME=rabbit@rabbit-B
NODE_IP_ADDRESS=178.101.20.161
NODE_PORT=5672
RABBITMQ_MNESIA_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\db
RABBITMQ_LOG_BASE=C:\Users\Administrator\AppData\Roaming\RabbitMQ\log
3、统一 .erlang.cookie 文件
erlang.cookie是erlang实现分布式的必要文件,erlang分布式的每个节点上要保持相同的.erlang.cookie文件。只有这个文件一致的节点,才能加入到集群中。
该文件一般存放在两个地方:
%WINDIR% (c:\Windows\.erlang.cookie) 此处在我的电脑上是: C:\Windows\System32\config\systemprofile\.erlang.cookie
%HOMEDRIVE%%HOMEPATH% (C:\Users\%USERNAME%\.erlang.cookie )
将所有位置的 cookie 文件都替换为机器 A 下的 cookie 文件(注意,此处说的是所有位置,两台机器有四个 cookie 文件,这个四个位置的 cookie 文件都必须相同)。
4、命令行中添加节点
在机器 A 中 :
1)、以管理员身份开启 cmd
2)、进入工具目录 cd c:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.6\sbin

3)、重置 RabbitMQ
rabbitmqctl stop_app rabbitmqctl reset rabbitmqctl start_app
在机器 B 中:
1)、以管理员身份开启 cmd
2)、进入工具目录
cd c:\Program Files\RabbitMQ Server\rabbitmq_server-3.6.\sbin
3)、添加 A 节点
rabbitmqctl stop_app
rabbitmqctl reset
rabbtimqctl join_cluster rabbit@rabbit-A
rabbitmqctl start_app
注意,此处在机器 A 中添加 B 节点与 B 中添加 A 节点是同一个效果。
这样就完成了集群的配置,现在可以在RabbitMQ Management 看到了。
下面是配置了三个节点之后的集群图:

相关的两个命令:
查看集群状态 : rabbitmqctl cluster_status
删除添加到集群中的队列:rabbitmqctl forget_cluster_node rabbit@rabbit-A
三、集群状态下发布消息优化
1、可用 DNS 负载均衡功能。申请一个域名,对应机器 A、B 的 IP 地址, 每次发布消息,可利用 dns 解析的特性自动实现负载均衡。
2、easynetq 随机选择域名
var bus = RabbitHutch.CreateBus("host=myfirsthost,mysecondhost", x => x.Register<IClusterHostSelectionStrategy<ConnectionFactoryInfo>, RandomClusterHostSelectionStrategy<ConnectionFactoryInfo>>());
四、消息镜像(高可用性)
未完待续。
参考:
http://www.rabbitmq.com/clustering.html
https://blog.csdn.net/u010029983/article/details/45337365
https://www.cnblogs.com/hegx/p/6097147.html
消息队列的使用 RabbitMQ (二): Windows 环境下集群的实现的更多相关文章
- 消息队列介绍、RabbitMQ&Redis的重点介绍与简单应用
消息队列介绍.RabbitMQ&Redis的重点介绍与简单应用 消息队列介绍.RabbitMQ.Redis 一.什么是消息队列 这个概念我们百度Google能查到一大堆文章,所以我就通俗的讲下 ...
- 进击的Python【第十一章】:消息队列介绍、RabbitMQ&Redis的重点介绍与简单应用
消息队列介绍.RabbitMQ.Redis 一.什么是消息队列 这个概念我们百度Google能查到一大堆文章,所以我就通俗的讲下消息队列的基本思路. 还记得原来写过Queue的文章,不管是线程queu ...
- RabbitMQ,Windows环境下安装搭建
切入正题:RabbitMQ的Windows环境下安装搭建 一.首先安装otp_win64_20.1.exe,,, 二.然后安装,rabbitmq-server-3.6.12.exe, 安装完成后,在服 ...
- RabbitMQ消息队列系列教程(二)Windows下安装和部署RabbitMQ
摘要 本篇经验将和大家介绍Windows下安装和部署RabbitMQ消息队列服务器,希望对大家的工作和学习有所帮助! 目录 一.Erlang语言环境的搭建 二.RabbitMQ服务环境的搭建 三.Ra ...
- RabbitMQ分布式消息队列服务器(一、Windows下安装和部署)
RabbitMQ消息队列服务器在Windows下的安装和部署-> 一.Erlang语言环境的搭建 RabbitMQ开源消息队列服务是使用Erlang语言开发的,因此我们要使用他就必须先进行Erl ...
- C# Queue与RabbitMQ的爱恨情仇(文末附源码):Q与MQ消息队列简单应用(二)
上一章我们讲了队列( Queue),这一章我们讲Message Queue消息队列,简称MQ. 定义: MQ是MessageQueue,消息队列的简称(是流行的开源消息队列系统,利用erlang语言开 ...
- RabbitMQ在Windows环境下的安装与使用
Windows下安装RabbitMQ 环境配置 部署环境 部署环境:windows server 2008 r2 enterprise 官方安装部署文档:http://www.rabbitmq.com ...
- (转)RabbitMQ消息队列(七):适用于云计算集群的远程调用(RPC)
在云计算环境中,很多时候需要用它其他机器的计算资源,我们有可能会在接收到Message进行处理时,会把一部分计算任务分配到其他节点来完成.那么,RabbitMQ如何使用RPC呢?在本篇文章中,我们将会 ...
- 消息队列的使用 RabbitMQ
RabbitMQ 是一款开源且比较流行的消息中间件.但用起来还是比较麻烦,有人封装了一层, 这就是 EasyNetQ . 一.安装 1.安装 Erlang: http://www.erlang.org ...
随机推荐
- ubuntu下cmake 使用clang
安装llvm.clang sudo apt-get install llvm clang clang命令会在/usr/bin/clang cmake配置交叉编译链 建立linux.toolchain. ...
- Tensorflow小技巧整理:修改张量特定元素的值
TensorFlow小技巧整理:修改张量特定元素的值 最近在做一个摘要生成的项目,过程中遇到了很多小问题,从网上查阅了许多别人解决不同问题的方法,自己也在旁边开了个jupyter notebook搞些 ...
- Java设计模式(六)Adapter适配器模式
一.场景描述 “仪器数据采集器”包含采集数据以及发送数据给服务器两行为,则可定义“仪器数据采集器”接口,定义两方法“采集数据capture”和“发送数据sendData”. “PDF文件数据采集器”实 ...
- Python进阶_类与实例
上一节将到面对对象必须先抽象模型,之后直接利用模型.这一节我们来具体理解一下这句话的意思. 面对对象最重要的概念就是类(class)和实例(instance),必须牢记类是抽象的模板,比如studen ...
- Eclipse项目出现红色叹号的解决办法
以前的项目今天打开突然出现了红色的叹号,对于强迫症的患者简直忍不了,出现红色叹号的原因都是jar包出现问题导致的,如果是代码错误早就是一个大红叉了- 打开项目就可以发现,找不到哪里出问题了,代码和js ...
- C++实验1
- [Noip2003 PJ] 数字游戏
Description & Range 丁丁最近沉迷于一个数字游戏之中.这个游戏看似简单,但丁丁在研究了许多天之后却发觉原来在简单的规则下想要赢得这个游戏并不那么容易.游戏是这样的,在你面前有 ...
- Tomcat服务器简单测试jsp文件和html文件
在tomcat里面的webapps文件夹下面新建一个test文件, 写一个test.html的文件,一个test.jsp的文件,两个文件的内容全是:2+2=<%=2+2%> 重新启动Tom ...
- 一个shell脚本,让你的linux命令行酷炫起来
可调用如下函数达到echo出来带颜色的文字.._echo_error() { echo -ne "\033[31;1m $1\033[0m\n";}_echo_ok() { ech ...
- 从零部署Spring boot项目到云服务器(准备工作)
自己的博客终于成功部署上线了,回过头来总结记录一下整个项目的部署过程! 测试地址:47.94.154.205:8084 注:文末有福利! 一.Linux下应用Shell通过SSH连接云服务器 //ss ...