热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

安装rabbitmq以及集群配置

前言:(一些有用没用的唠叨,反正看了也不少肉,跳过也没啥)情况是这样的:虚拟机、CentOS6.5、免编译包安装rabbitmq集群,可不用连外网。我原计划是安装在虚

前言:

(一些有用没用的唠叨,反正看了也不少肉,跳过也没啥)

情况是这样的:虚拟机、CentOS 6.5、免编译包安装rabbitmq集群,可不用连外网。

我原计划是安装在虚拟机上wyt1/wyt2/wyt3/wyt4,后来实际用了两个节点,其实多增加节点的方法是一样的,就先不弄那么多啦。

  截图下面

     不同的OS或者安装方式自己琢磨看,然后注意下箭头的两个part

这两个part也要看,因为我就是没看erlang的版本导致一开始失败的,官网写着运行rabbitmq需要erlang的最小版
本是R16B03,如果非要用旧版本的erlang,那么用rabbitmq3.5版本的,这个可以用R13B03,并且如果是集群的
模式,要保证节点用的erlang的版本一致。

(0)安装依赖包:

每个节点都要装,反正各个节点命令敲一次,虽然包有点多,要是嫌烦我就不知道怎么办了,可能需要先去治治懒

tk、tcl、unixODBC、ncurses*、gcc* make ncurses-devel libxslt xsltproc unzip xmlto zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel      我没有找到libpcap-devel,只装了libpcap

# yum -y install libxslt-1.1.26-2.el6_3.1.x86_64.rpm

# yum -y install xmlto-0.0.23-3.el6.x86_64.rpm

上面这两个是单独装的,因为直接

# yum install -y libxslt* xmlto*    报错

 

 

xmlto是rabbitmq编译安装时用

ODBC是erlang用的

  

(1)安装ERLANG

1.1)下载erlang安装包

首先,因为RabbitMQ由ERLANG实现,下载ERLANG 源代码。

官网下载地址:  http://erlang.org/download/     去下载箭头指的这个玩意

 

 或者: [root@wyt1 ~]# wget http://www.erlang.org/download/otp_src_19.2.tar.gz

1.2)将安装包scp到别的节点

[root@wyt1 ~]# scp otp_src_19.2.tar.gz root@wyt2:/root

[root@wyt1 ~]# scp otp_src_19.2.tar.gz root@wyt3:/root

[root@wyt1 ~]# scp otp_src_19.2.tar.gz root@wyt4:/root

1.3)安装erlang

每个节点:

# mkdir -p /usr/local/erlang

# tar -zxvf  otp_src_19.2.tar.gz

# cd otp_src_19.2

# ./configure --prefix=/usr/local/erlang

# make

# make install

在 ./configure之后可能

报下面的东西(以wyt1为例)

[root@wyt1 otp_src_19.2]# ./configure --prefix=/usr/local/erlang

*********************************************************************

**********************  APPLICATIONS INFORMATION  *******************

*********************************************************************

 

wx             : wxWidgets not found, wx will NOT be usable

 

*********************************************************************

*********************************************************************

**********************  DOCUMENTATION INFORMATION  ******************

*********************************************************************

 

documentation  :

                 fop is missing.

                 Using fakefop to generate placeholder PDF files.

 

*********************************************************************

 之后发现这个没有影响,就是一些document巴拉巴拉的,详见下面这篇blog,感谢博主!

http://blog.csdn.net/clodfront/article/details/7930175

 反正没装那个wxWidgets库也能装好erlang,如果你是强迫症处女座,非要安装,就看这个链接:http://www.tuicool.com/articles/iIruqyA   (感谢网络爬虫,更感谢博主)

  1.4)添加erlang环境变量(4台都做,下面以wyt1为例)

[root@wyt1 bin]# vim /etc/profile

ERLANG=/usr/local/erlang

PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin:$GOROOT/bin:$ZOOKEEPER_HOME/bin:$GOPATH/bin:$GIT/bin:$MYSQL/bin:$MYSQL/lib:$ERLANG/bin

export GOROOT GOPATH JAVA_HOME JRE_HOME CLASSPATH PATH ZOOKEEPER_HOME GIT MYSQL MYCAT_HOME ERLANG

[root@wyt1 bin]# source /etc/profile

[root@wyt1 bin]# which erl

/usr/local/erlang/bin/erl

 

1.5)测试erlang(下面以wyt1为例)

[root@wyt1 ~]# erl

Erlang/OTP 19 [erts-8.2] [source] [64-bit] [async-threads:10] [hipe] [kernel-poll:false]

 

Eshell V8.2  (abort with ^G)

1> io:format("hello world ~n").

hello world --------安装成功

ok

2> ---------------注意,这个地方是按快捷键Ctrl+C,然后选a就退出来了

BREAK: (a)bort (c)ontinue (p)roc info (i)nfo (l)oaded

       (v)ersion (k)ill (D)b-tables (d)istribution

a

[root@wyt1 ~]#

 

(2)安装 python

CentOS 6.5的自带python是2.6.6,

查看python版本

# python -V

Python 2.6.6

用2.6以上的版本就不用安装SampleJson,否则要安装,

 

安装samplejson方法(我之所以安装是因为一开始不知道可以不用安装,,,抛出安装方法拯救低版本的python,以wyt1为例)

[root@wyt1 ~]# cd simplejson-3.10.0

[root@wyt1 simplejson-3.10.0]# python setup.py install

 

 

(3)安装 rabbitmq-server(无特殊指定步骤,下面的步骤每个节点都要进行)

3.1)下载二进制免编译的包

下载地址:http://www.rabbitmq.com/install-generic-unix.html

 

3.2)安装

上传安装包到每台虚拟机

# tar -vxJf rabbitmq-server-generic-unix-3.6.6.tar.xz -C /usr/local/

# cd /usr/local/

# mv rabbitmq_server-3.6.6 rabbitmq

 

3.3)基本配置

 

上面内容大致的意思是可以自定义rabbitmq环境的环境变量,

位置和文件是$RABBITMQ_HOME/etc/rabbitmq/rabbitmq-env.conf,

服务的组件也要配置,位置在$RABBITMQ_HOME/etc/rabbitmq/rabbitmq.config

并且这两个文件在安装都不存在,需要自己创建。

 

3.3.1) 首先在profile中加入$RABBITMQ_HOME

# vim /etc/profile

# source /etc/profile

#  tail /etc/profile

JRE_HOME=/usr/local/java/jdk/jre

CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib

ZOOKEEPER_HOME=/usr/local/zookeeper

GIT=/usr/local/git

MYSQL=/usr/local/mysql

ERLANG=/usr/local/erlang

RABBITMQ_HOME=/usr/local/rabbitmq

PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin:$GOROOT/bin:$ZOOKEEPER_HOME/bin:$GOPATH/bin:$GIT/bin:$MYSQL/bin:$MYSQL/lib:$ERLANG/bin:$PYTHON/bin:$RABBITMQ_HOME/sbin

export GOROOT GOPATH JAVA_HOME JRE_HOME CLASSPATH PATH ZOOKEEPER_HOME GIT MYSQL MYCAT_HOME ERLANG RABBITMQ_HOME

 

3.3.2)创建两个相应的文件

# cd /usr/local/rabbitmq/etc/rabbitmq

# touch rabbitmq-env.conf

# touch rabbitmq.config

3.3.3)修改config文件,加入下面的键值对,为了用web页面管理rabbitmq时可以用guest通过非localhost登录

 

# vim rabbitmq.config

# cat rabbitmq.config

[{rabbit, [{loopback_users, []}]}].

详见官网: http://www.rabbitmq.com/access-control.html

 

 

3.4)修改用户资源限制(启动之前)

 

# ulimit -S -n

1024

# ulimit -S -n 4096

# ulimit -S -n

4096

3.5)检查端口占用,保证下述端口没有被用

 

(4)使用rabbitmq

4.1)启动wyt1节点 ,先测试一下是否安装成功,也是为了在$HOME下生成之后集群用的 .erlang.COOKIE 文件

[root@wyt1 ~]# cd /usr/local/rabbitmq/sbin

[root@wyt1 sbin]# ./rabbitmq-server start

 

              RabbitMQ 3.6.6. Copyright (C) 2007-2016 Pivotal Software, Inc.

  ##  ##      Licensed under the MPL.  See http://www.rabbitmq.com/

  ##  ##

  ##########  Logs: /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt1.log

  ######  ##        /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt1-sasl.log

  ##########

              Starting broker...

 completed with 0 plugins.

[root@wyt1 ~]#

可以看到成功启动后会生成log文件和路径 /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt1.log

 

 服务的端口也相应起来

 

4.2)启用web管理插件

[why@wyt1 sbin]$  ./rabbitmq-plugins list-----查看一下启动前的

[why@wyt1 sbin]$  ./rabbitmq-plugins enable rabbitmq_management

The following plugins have been enabled:

  mochiweb

  webmachine

  rabbitmq_web_dispatch

  amqp_client

  rabbitmq_management_agent

  rabbitmq_management

 

Applying plugin configuration to rabbit@wyt1... started 6 plugins.

[why@wyt1 sbin]$  ./rabbitmq-plugins list-----启动后再看一下

4.3)登录web管理界面

浏览器:http://192.168.6.11:15672

用户:guest 密码:guest

 

 

4.4)停止

[why@wyt1 sbin]$ ./rabbitmqctl stop

Stopping and halting node rabbit@wyt1 ...

Gracefully halting Erlang VM

[why@wyt1 sbin]$

 

官网: http://www.rabbitmq.com/install-generic-unix.html

 

(5)rabbitmq集群设置(我这里只用wyt1和wyt2两个节点,加上其余的节点方法是一样的)

官网集群配置地址: http://www.rabbitmq.com/clustering.html

5.1)确认一下hosts解析是否配好

(截屏wyt2为例),因为集群的通讯是靠hostname的

 

 

官网解释:

 

5.2)配置集群前要保证参与集群的node是能够单点启动的,所以先验证一下wyt2节点是不是能够启动

[root@wyt2 sbin]# ./rabbitmq-server start

[root@wyt2 sbin]# ./rabbitmq-plugins enable rabbitmq_management

http://192.168.6.10:15672

[root@wyt2 sbin]# ./rabbitmqctl stop

 5.3)保证每个节点的.erlang.COOKIE文件一致。

 

刚才wyt1节点启动后会在root家目录生成.erlang.COOKIE文件,将这个文件scp到别的节点root的家目录下

5.3.1)删掉wyt2节点的COOKIE文件

[root@wyt2 ~]# rm -rf .erlang.COOKIE

5.3.2)将节点一的拷贝过去,也可以在wyt2节点启动之前就将wyt1节点的COOKIE文件放过去

[root@wyt1 ~]# scp .erlang.COOKIE root@wyt2:/root

注意:这个文件的权限是400,我直接将wyt2节点启动后的.erlang.COOKIE文件删了,如果想要修改,需要chmod 600 .erlang.COOKIE,修改之后还要再改回400权限chmod 400 .erlang.COOKIE

 

5.4)将节点1和2放到后台启动:

[root@wyt1 sbin]#   ./rabbitmq-server  -detached

[root@wyt2 sbin]# ./rabbitmq-server –detached

 详见官网是以三个节点为例:

启动时可以实时看到log文件的记录(我是习惯性的看看,万一 有ERROR什么的):

下面简要取wyt2的日志的内容

=INFO REPORT==== 8-Feb-2017::18:55:56 ===

Starting RabbitMQ 3.6.6 on Erlang 19.2

Copyright (C) 2007-2016 Pivotal Software, Inc.

Licensed under the MPL.  See http://www.rabbitmq.com/

 

=INFO REPORT==== 8-Feb-2017::18:55:56 ===

node           : rabbit@wyt2

home dir       : /root

config file(s) : /usr/local/rabbitmq/etc/rabbitmq/rabbitmq.config

COOKIE hash    : iBUGZ1/RD/8OxjPAPuyi2Q==

log            : /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt2.log

sasl log       : /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt2-sasl.log

database dir   : /usr/local/rabbitmq/var/lib/rabbitmq/mnesia/rabbit@wyt2

可以看一下状态

 

5.5)集群配置

5.5.1)加入集群前查看一下每个节点的集群状态,这个时候只有自己节点

[root@wyt1 sbin]# ./rabbitmqctl cluster_status

Cluster status of node rabbit@wyt1 ...

[{nodes,[{disc,[rabbit@wyt1]}]},

 {running_nodes,[rabbit@wyt1]},

 {cluster_name,<<"rabbit@localhost">>},

 {partitions,[]},

 {alarms,[{rabbit@wyt1,[]}]}]

 

[root@wyt2 sbin]# ./rabbitmqctl cluster_status

Cluster status of node rabbit@wyt2 ...

[{nodes,[{disc,[rabbit@wyt2]}]},

 {running_nodes,[rabbit@wyt2]},

 {cluster_name,<<"rabbit@localhost">>},

 {partitions,[]},

 {alarms,[{rabbit@wyt2,[]}]}]

 

5.5.2)将节点wyt2加入集群

[root@wyt2 sbin]# ./rabbitmqctl stop_app  (这里是stop_app而不是直接关闭节点的stop)

Stopping node rabbit@wyt2 ...

[root@wyt2 sbin]#

log日志截图

 

 

[root@wyt2 sbin]# ./rabbitmqctl join_cluster rabbit@wyt1

Clustering node rabbit@wyt2 with rabbit@wyt1 ...

[root@wyt2 sbin]#

log日志截图:

 

 

[root@wyt2 sbin]# ./rabbitmqctl start_app

Starting node rabbit@wyt2 ...

 

              RabbitMQ 3.6.6. Copyright (C) 2007-2016 Pivotal Software, Inc.

  ##  ##      Licensed under the MPL.  See http://www.rabbitmq.com/

  ##  ##

  ##########  Logs: /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt2.log

  ######  ##        /usr/local/rabbitmq/var/log/rabbitmq/rabbit@wyt2-sasl.log

  ##########

              Starting broker...

 completed with 6 plugins.

[root@wyt2 sbin]#

5.5.3)查看节点的集群状态

[root@wyt2 sbin]# ./rabbitmqctl cluster_status

Cluster status of node rabbit@wyt2 ...

[{nodes,[{disc,[rabbit@wyt1,rabbit@wyt2]}]},

 {running_nodes,[rabbit@wyt1,rabbit@wyt2]},

 {cluster_name,<<"rabbit@localhost">>},

 {partitions,[]},

 {alarms,[{rabbit@wyt1,[]},{rabbit@wyt2,[]}]}]

 

[root@wyt1 sbin]# ./rabbitmqctl cluster_status

Cluster status of node rabbit@wyt1 ...

[{nodes,[{disc,[rabbit@wyt1,rabbit@wyt2]}]},

 {running_nodes,[rabbit@wyt2,rabbit@wyt1]},

 {cluster_name,<<"rabbit@localhost">>},

 {partitions,[]},

 {alarms,[{rabbit@wyt2,[]},{rabbit@wyt1,[]}]}]

 

可以看到管理界面是两个节点了

 

详见官网:

 

 

注:非root用户的安装唯一区别就是erlang和rabbitmq_home环境变量的位置改写,文档要不要整理看我心情和时间。

[why@wyt3 ~]$ cat .bash_profile

# .bash_profile

 

# Get the aliases and functions

if [ -f ~/.bashrc ]; then

. ~/.bashrc

fi

 

# User specific environment and startup programs

ERLANG=/home/why/erlang

RABBITMQ_HOME=/home/why/rabbitmq

PATH=/home/why/mysql/bin:$PATH:$HOME/bin:$ERLANG/bin:$RABBITMQ_HOME/sbin

export PATH ERLANG RABBITMQ_HOME

 

 

 

 

***************************************** OVER *********************************************



推荐阅读
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 树莓派语音控制的配置方法和步骤
    本文介绍了在树莓派上实现语音控制的配置方法和步骤。首先感谢博主Eoman的帮助,文章参考了他的内容。树莓派的配置需要通过sudo raspi-config进行,然后使用Eoman的控制方法,即安装wiringPi库并编写控制引脚的脚本。具体的安装步骤和脚本编写方法在文章中详细介绍。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
  • 本文介绍了5个基本Linux命令行工具的现代化替代品,包括du、top和ncdu。这些替代品在功能上进行了改进,提高了可用性,并且适用于现代化系统。其中,ncdu是du的替代品,它提供了与du类似的结果,但在一个基于curses的交互式界面中,重点关注占用磁盘空间较多的目录。 ... [详细]
  • 本文整理了Java中com.evernote.android.job.JobRequest.getTransientExtras()方法的一些代码示例,展示了 ... [详细]
  • 前言整个信息技术的很多领域,都是相互关联的,IT也是一样,他们有着他们的规律,在其中摩尔定律,安迪——比尔定律,反摩尔定律组成了计算机行业的发展规律摩尔定律科技行业流传着一个 ... [详细]
  • uboot与linux驱动1.uboot本身是裸机程序(1)在裸机中本来是没有驱动概念的(狭义的驱动概念是指在操作系统中用来具体操控硬 ... [详细]
  • 基于SSL的mysql服务器的主从架构实现说明:本文选用172.16.22.1作为主服务器,172.16.22.3作为从服务器从服务器的mysql软件版 ... [详细]
  • 本文讲述了CodeForces1016C题目的解法。文章首先介绍了一种错误的理解,然后给出了正确的解法。其中,当位于一个角上时,有两种选择,一种是先一直走一行再返回来走,另一种是走到这一列的另一行上然后再往右走一列。作者给出了两种解法,一种是直接计算,一种是动态规划。最后,取两种解法的最优解作为答案。文章附上了源代码。 ... [详细]
author-avatar
好kc好先生之家
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有