rabibtMQ安装及集群配置-linux
安装RabbitMQ
RabbitMQ是流行的开源消息队列系统,用erlang语言开发,故首先需要安装erlang依赖及erlang。
安装erlang依赖的基本环境,通过yum方式进行安装:
yum -yinstallgcc glibc-develmakencurses-devel openssl-devel autoconf下载并安装erlang,这里使用的是erlang-R15B-02.1.el6.x86_64.rpm,将其拷贝至虚机中并通过yum方式进行安装:
yum -yinstallerlang-R15B-02.1.el6.x86_64.rpm- 测试erlang环境,输入erl

下载rabbitmq官方server版并安装
地址:http://www.rabbitmq.com/install-rpm.html
这里使用的是rabbitmq-server-3.3.5-1.noarch.rpm版本,通过xftp软件或者其他方式上传到虚拟机中,使用yum方式进行安装:yum -yinstallrabbitmq-server-3.3.5-1.noarch.rpm
启动RabbitMQ
通过系统服务启动rabbitmq-server

如果无法正常启动,则可以通过日志进行故障排查
另外通过chkconfig命令可以查看rabbitmq服务是否已经启动:chkconfig --list rabbitmq-server开启RabbitMQ Web管理插件
首先查看插件list的相关信息:rabbitmq-plugins list启动web管理插件:
rabbitmq-pluginsenablerabbitmq_management如果成功启动插件,使用service rabbitmq-server restart命令重启rabbitmq服务,使其生效。
访问web管理插件界面
通过浏览器打开web界面,地址为http://ip:15672/mgmt/,默认的用户名和密码均为guest。
如果无法访问,查看rabbitmq日志信息,可能原因主要有两方面:端口15672被占用、防火墙开启。
通过下面命令关闭防火墙,建议设置为开机自动关闭:service iptables stopchkconfig iptables offGuest账户无法登陆web管理界面
出于安全性的考虑,rabbitmq从3.3版本以后,guest用户默认只能通过localhost才能登陆使用。
这里可以通过创建rabbitmq.config文件,解除上述访问限制。vi/etc/rabbitmq/rabbitmq.config# 内容如下[{rabbit,[%%%% Network Connectivity%% ====================%%%% By default, RabbitMQ will listen on all interfaces, using%% the standard (reserved) AMQP port.%%{tcp_listeners, [5672]},{loopback_users, ["admin"]}]}].
搭建RabbitMQ集群
Rabbitmq的集群是依赖于erlang的集群来工作的,所以必须先构建起erlang的集群环境。
Erlang的集群中各节点是通过一个magic cookie来实现的,这个cookie存放在.erlang.cookie 中,
故必须保证各节点cookie保持一致,否则节点之间就无法通信。建议在做下列操作前,关闭rabbitmq-server服务。
设置节点cookie
cookie文件位于/var/lib/rabbitmq下
将该节点的.erlang.cookie文件内容(如下面的"XXXXXXXXXXXXX"字符串)复制到其他所有节点的同文件中,记得要先赋予文件写权限,写完后再取消写权限:chmod700 .erlang.cookieecho-n"XXXXXXXXXXXXX"> .erlang.cookiechmod400 .erlang.cookie注意:复制字符串时,千万不要带上空格等无用信息
- 确保节点间主机名称可以相互解析
将集群中全部机器的(ip地址 主机名)分别添加到每台机器的hosts文件中:
节点组成集群
首先启动rabbitmq-server的服务,运行各个机器的节点,并查看状态:service rabbitmq-server startrabbitmqctl stoprabbitmq-server -detachedrabbitmqctl status假设有三台机器,分别为node1、node2、node3,那么下面将node2和node3与node1组成集群(即在node2和node3两台机器中做如下操作):
rabbitmqctl stop_apprabbitmqctl join_cluster rabbit@node1rabbitmqctl start_app配置完成后,可以在任意节点机器上执行 rabbitmqctl cluster_status 来查看是否集群配置成功:

设置镜像队列策略
在任意节点上执行下列策略,将所有队列设置为镜像队列,即队列会被复制到各个节点,各个节点状态保持一致。当有新节点加入集群时,队列将被镜像到那个节点。
rabbitmqctl set_policy ha-all"^"'{"ha-mode":"all"}'节点退出集群
以node1节点为例,如果需要将其退出集群
rabbitmqctl stop_apprabbitmqctl rest
创建集群用户
由于后面部署BuildPlatform时,所用到的rabbitmq账户为admin,密码为123456。
因此这里需要首先创建用户,方法主要有两个:
- Web管理页面创建
使用guest账户登陆web管理界面后,点击Admin标签,原本只有一个guest账户,
这里新建admin账户,设置密码,并选中名为[Admin]的Tags:
点击页面右侧的Virtual Host标签后,进入下图中方框的链接:
找到Set permission部分,将admin用户添加到当前Permissions中:
命令行方式创建
创建admin用户rabbitmqctl add_user admin 123456设置admin用户administrator角色rabbitmqctl set_user_tags admin administrator查看已创建用户rabbitmqctl list_users赋予admin用户权限rabbitmqctl set_permissions -p / admin'.*''.*''.*'上述命令确保用户admin具有/这个virtual host中所有资源配置、写、读权限,以便管理其中的资源
建议
强烈建议将RabbitMQ服务设置为开机自启动:
chkconfig rabbitmq-server onrabibtMQ安装及集群配置-linux的更多相关文章
- 从零开始安装Redis 集群(Linux CenOS7)
从零开始安装Redis 集群(Linux CenOS7) 使用ISO安装CentOS7虚拟机 配置静态IP(参考Mac VMware Fusion CentOS7配置静态IP) 安装vim [root ...
- rocketMq安装及集群配置
网上关于rocketMq安装.集群配置的文章有很多,作为一个初学者,跟着网上的各种教程安装遇到了各种坑,可谓是一路坎坷.本文记录下rocketMq安装的完整过程.希望对你有一点帮助 安装rocketM ...
- Zookeeper 安装及集群配置注意点
Zookeeper在ubuntu下安装及集群搭建,关于集群搭建,网上很多文章 可以参考:https://www.ibm.com/developerworks/cn/opensource/os-cn-z ...
- zookeeper的安装及集群配置
1.解压 2.修改配置文件 cp zoo_sample.cfg zoo.cfg vim zoo.cfg dataDir=/usr/local/zookeeperData 其余采用默认 参数说明: ti ...
- CentOS7+CDH5.14.0安装全流程记录,图文详解全程实测-8CDH5安装和集群配置
Cloudera Manager Server和Agent都启动以后,就可以进行CDH5的安装配置了. 准备文件 从 http://archive.cloudera.com/cdh5/par ...
- Elasticsearch 安装与集群配置
一.软件版本 操作系统:CentOS-6.5-x86_64 ES版本:5.0 主机:192.168.63.246 主机: 192.168.63.242 二.部署环境规划: 1. 需求:jdk版本: ...
- hadoop分布式安装及其集群配置笔记
各机器及角色信息: 共10台机器,hostname与ip地址映射在此不做赘述.此为模拟开发环境安装,所以不考虑将NameNode和SecondaryNameNode安装在同一台机器. 节点 角色 na ...
- elasticsearch简单的安装以及集群配置详解
首先要确保有java8的环境,安装方法如下(centos) wget --no-check-certificate --no-cookies --header "Cookie: oracle ...
- Redis集合 安装 哨兵集群 配置
redis相关 redis基础 redis发布订阅 redis持久化RDB与AOF redis不重启,切换RDB备份到AOF备份 redis安全配置 redis主从同步 redis哨兵集群 redis ...
随机推荐
- Mac OS X中报:java.io.UnixFileSystem.createFileExclusively(Native Method)的简单原因
这个博客太简单了!想到可能有其它朋友也遇到这个问题,就记录一下. 今天把一个之前在Windows上的Java项目放到Mac OS X上执行,本来认为应该非常easy的事情,结果还是报: Excepti ...
- Binary Tree Maximum Path Sum [leetcode] dp
a(i):在节点i由于单边路径的最大结束 b(i):在节点i路径和 a(i) = max{ i->val, i->val + max{a(i->left), a(i->righ ...
- 你可以不知道原因,但是,我们不能停止努力。httplook抓取路由配置界面信息
因为实验室的项目要求,需要动态控制路由的配置信息,我们知道.路由选择需要购买的访问后,:http://192.168.1.1 路由配置页面.配置,不须要人手工操作.甚至定时任务配置的时候,就须要进一步 ...
- jquery选择器中逗号的使用
1.多条件选择器 多条件选择器:$("p,div,span.menuitem"),同时选择p标签,div标签,和拥有menuitem样式的span标签元素 <table id ...
- js 正则学习小记之左最长规则
原文:js 正则学习小记之左最长规则 昨天我在判断正则引擎用到的方法是用 /nfa|nfa not/ 去匹配 "nfa not",得到的结果是 'nfa'.其实我们的本意是想得到整 ...
- MVC中实现多按钮提交(转)
有时候会遇到这种情况:在一个表单上需要多个按钮来完成不同的功能,比如一个简单的审批功能. 如果是用webform那不需要讨论,但asp.net mvc中一个表单只能提交到一个Action处理,相对比较 ...
- c/cpp中怎样切割字符串,相似于split的功能
在python中,假设要求当前时间的unix时间戳,我特别喜欢这么用: import time timestr = time.time() timestamp = int(timestr.split( ...
- Redis 上实现的分布式锁
转载Redis 上实现的分布式锁 由于近排很忙,忙各种事情,还有工作上的项目,已经超过一个月没写博客了,确实有点惭愧啊,没能每天或者至少每周坚持写一篇博客.这一个月里面接触到很多新知识,同时也遇到很多 ...
- iOS8自适应布局视频教程
联系:http://www.elsyy.com/course/6480 这是颐和园最近录制iOS8视频课程.简介iOS8出现在自适应布局. 本教程的书,颐和园<ios8 swift编程指南> ...
- Shuttle ESB
Shuttle ESB(六)——在项目中的应用 如果说你认真看了前面几篇关于ESB的介绍,我相信,在这一篇文章中,你将会找到很多共鸣. 尽管,市面上开源的ESB确实非常之多,像Java中的Mule E ...