【说明】
1.如果是可以连外网的环境建议直接使用yum安装rabbitmq,这样省去很多中间过程,不必要看本帖
2.由于个人的环境不同,建议可以直接进行安装,缺什么依赖安装什么依赖,切记不要照抄所有步骤,涉及所有安装包见本人上传文件链接:https://download.csdn.net/download/cow_cz/10463075
3.这次整理为搭建单节点的rabbitmq,关于集群的搭建下次整理
4.本帖参考很多高人的内容,如有问题请与本人联系
因为rabbitmq是用Erlang语言进行开发的,所以搭建rabbitmq环境前必须要先搭建Erlang环境。
首先说明下二郎神环境搭建是比较繁琐的,不过只要二郎神可以了,rabbitmq自然也就不在话下了。
注意:erlang和rabbitmq的版本要对应起来,具体怎么对应不清楚。。。但是本人安装erlang 20.1 然后安装rabbitmq 3.6.2就各种问题,换了3.6.9才ok的
根据自己环境已经要安装的rabbitmq版本确定自己要下载的erlang版本。我的环境是:Redhat 3.10.0-123.el7.x86_64、erlang 20.1、rabbitmq 3.6.9。
下载 otp_src_20.1.tar.gz 安装包,放置在安装目录下,我这边是:/cao/soft/tools
解压安装erlang:
[cao@cao tools]$ cd otp_src_20.1/
[cao@cao otp_src_20.1]$ ./otp_build autoconf
[cao@cao otp_src_20.1]$ ./configure --prefix=/cao/soft/tools/erlang
参数:–prefix=/cao/soft/tools/erlang 根据个人安装路径决定
这里一般会报错,根据报错安装需要的依赖包,我这边是:
checking for kstat_open in -lkstat... (cached) no
checking for tgetent in -ltinfo... no
checking for tgetent in -lncurses... no
checking for tgetent in -lcurses... no
checking for tgetent in -ltermcap... no
checking for tgetent in -ltermlib... no
configure: error: No curses library functions found
configure: error: /cao/soft/tools/otp_src_20.1/erts/configure failed for erts
根据提示明显是没有安装ncurses下载安装包安装。温馨提示下:如果是在个人虚拟机安装rabbitmq的话,建议选用自带的安装包进行安装,目录:/run/media/主机名/RHEL-系统版本号/Packages,这样省事不说兼容性也没问题。
下载ncurses-devel地址:https://pkgs.org/download/ncurses-devel
我这边直接选取环境上的安装包ncurses-devel-5.9-13.20130511.el7.x86_64.rpm进行安装,需要root权限:
[root@cao tools]# rpm -ivh ncurses-devel-5.9-13.20130511.el7.x86_64.rpm
警告:ncurses-devel-5.9-13.20130511.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:ncurses-devel-5.9-13.20130511.el7################################# [100%]
安装ncurses-devel之前可以用rpm查看下环境是否已经安装ncurses,没有的话需要一起安装上,查看命令: rpm -qa |grep ncurses,可在任意目录下执行
此步安装结束后,再次按照1.2开始安装erlang,执行:
[cao@cao otp_src_20.1]$ ./configure --prefix=/cao/soft/tools/erlang
这里报错如下图:
说明:我们主需要解决APPLICATIONS DISABLED报错的内容,其他的可以不用处理
有些环境可能还有其他报错,比如:
openssl-devel not found
No Java compiler found
ODBC library - link check failed
这样的话除了缺少unixODBC还需要openssl-devel,其中No Java compiler found,如果环境中安装了gcc可以不用java编译(网上写的加–without-javac,但是我这边不起作用,有兴趣可以试下),接下来我们逐一安装。
openssl-devel下载地址:https://pkgs.org/download/openssl-devel
openssl下载地址:https://www.openssl.org/source/
根据需要自行下载,我这边只需要下载openssl-devel包,开始安装:
[cao@cao tools]$ rpm -ivh openssl-devel-1.0.1e-34.el7.x86_64.rpm
警告:openssl-devel-1.0.1e-34.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
错误:依赖检测失败:
krb5-devel(x86-64) 被 openssl-devel-1:1.0.1e-34.el7.x86_64 需要
zlib-devel(x86-64) 被 openssl-devel-1:1.0.1e-34.el7.x86_64 需要
这里提示要依赖包没有安装,我的方法是找到这俩个包然后安装,因为zlib,krb5包不安装的话后边用到openssl还是会报错。
安装zlib-devel:(–nodeps之间安装不进行依赖性检查)
[root@cao tools]# rpm -ivh zlib-devel-1.2.7-13.el7.x86_64.rpm --nodeps
安装krb5-devel:
[root@cao tools]# rpm -ivh krb5-devel-1.11.3-49.el7.x86_64.rpm --nodeps
这两部安装完之后,再次安装openssl-devel即可
下载unixODBC:http://www.unixodbc.org/
同样可以先看下环境中安装了的包,我这边unixODBC都没有安装:
[cao@cao tools]$ su root
密码:
[root@cao tools]# rpm -ivh unixODBC-2.3.1-10.el7.x86_64.rpm
警告:unixODBC-2.3.1-10.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:unixODBC-2.3.1-10.el7 ################################# [100%]
[root@cao tools]# rpm -ivh unixODBC-devel-2.3.1-10.el7.x86_64.rpm
警告:unixODBC-devel-2.3.1-10.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:unixODBC-devel-2.3.1-10.el7 ################################# [100%]
安装jdk要注意的地方是设置环境变量,我的环境这边可能之前就已经装好了,这块没有进行修改,需要可以自行百度下,先看下已经安装的包:
[cao@cao otp_src_20.1]$ rpm -qa |grep java
python-javapackages-3.4.1-5.el7.noarch
java-1.7.0-openjdk-headless-1.7.0.51-2.4.5.5.el7.x86_64
java-1.7.0-openjdk-1.7.0.51-2.4.5.5.el7.x86_64
javapackages-tools-3.4.1-5.el7.noarch
tzdata-java-2014b-1.el7.noarch
缺少对应的java-1.7.0-openjdk-devel包,故进行安装:
[root@cao tools]# rpm -ivh java-1.7.0-openjdk-devel-1.7.0.51-2.4.5.5.el7.x86_64.rpm
警告:java-1.7.0-openjdk-devel-1.7.0.51-2.4.5.5.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:java-1.7.0-openjdk-devel-1:1.7.0.################################# [100%]
[root@cao tools]#
到此基本上需要的依赖包都安装结束了,其他的我没有遇到如果有其他需要,方法类似直接安装即可。 接下来再次安装erlang:
[cao@cao otp_src_20.1]$ ./otp_build autoconf
...中间略...
[cao@cao otp_src_20.1]$ ./configure --prefix=/cao/soft/tools/erlang --without-javac
...中间略...
[cao@cao otp_src_20.1]$make
...中间略...
[cao@cao otp_src_20.1]$make install ...
可以设置软连接也可以设置环境变量,我这边选取前者,在任意目录下执行:
ln -s /cao/soft/tools/erlang/bin/erl /usr/bin/erl
####1.4验证erlang环境
执行以下命令有正确回显证明安装成功:
[cao@cao sbin]$ erl
Erlang/OTP 20 [erts-9.1] [source] [64-bit] [smp:1:1] [ds:1:1:10] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V9.1 (abort with ^G)
1>
经过多次尝试,使用源码直接安装总是不成功,所以选取了通用版本进行安装的。
官网下载地址:http://www.rabbitmq.com/install-generic-unix.html
选取安装包为:rabbitmq-server-generic-unix-3.6.9.tar.xz
解压缩:
[cao@cao tools]$ tar -xvf rabbitmq-server-generic-unix-3.6.9.tar.xz
移动解压后的目录到 /usr/local下并且重命名为rabbitmq: (也可以不移动,只要环境变量设置到对应路径即可)
[cao@cao tools]$ mv rabbitmq_server-3.6.9 /usr/local/rabbitmq
打开/etc/profile文件,在文件最后添如下环境变量
#set rabbitmq environment
export PATH=$PATH:/usr/local/rabbitmq/sbin
使环境变量生效:
[cao@cao tools]$ source /etc/profile
安装rabbitmq完成,接下来进行配置的修改
进入目录/usr/local/rabbitmq/sbin/,执行启动服务的命令:
[cao@cao sbin]$ ./rabbitmq-server
RabbitMQ 3.6.9. Copyright (C) 2007-2016 Pivotal Software, Inc.
## ## Licensed under the MPL. See http://www.rabbitmq.com/
## ##
########## Logs: /usr/local/rabbitmq/var/log/rabbitmq/rabbit@cao.log
###### ## /usr/local/rabbitmq/var/log/rabbitmq/rabbit@cao-sasl.log
##########
Starting broker...
completed with 6 plugins.
出现上示结果说明服务启动成功,不要关闭该窗口,当然也可以加参数–detached后台启动 如果有报错:
[cao@cao sbin]$ ./rabbitmq-server ERROR: node with name "rabbit" already running on "cao"
则是因为rabbitmq服务已经启动,参考以下方法解决:找到已经启动的进程,然后kill,再次重启:
[cao@cao sbin]$ ps -ef |grep rabbitmq
cao 8872 8401 0 15:47 pts/0 00:00:00 /bin/sh -e ./rabbitmq-server
cao 8997 8872 0 15:47 pts/0 00:00:05 /cao/soft/tools/erlang/lib/erlang/erts-9.1/bin/beam.smp -W w -A 64 -P 1048576 -t 5000000 -stbt db -zdbbl 32000 -K true -B i -- -root /cao/soft/tools/erlang/lib/erlang -progname erl -- -home /home/cao -- -pa /usr/local/rabbitmq/ebin -noshell -noinput -s rabbit boot -sname rabbit@cao -boot start_sasl -kernel inet_default_connect_options [{nodelay,true}] -sasl errlog_type error -sasl sasl_error_logger false -rabbit error_logger {file,"/usr/local/rabbitmq/var/log/rabbitmq/rabbit@cao.log"} -rabbit sasl_error_logger {file,"/usr/local/rabbitmq/var/log/rabbitmq/rabbit@cao-sasl.log"} -rabbit enabled_plugins_file "/usr/local/rabbitmq/etc/rabbitmq/enabled_plugins" -rabbit plugins_dir "/usr/local/rabbitmq/plugins" -rabbit plugins_expand_dir "/usr/local/rabbitmq/var/lib/rabbitmq/mnesia/rabbit@cao-plugins-expand" -os_mon start_cpu_sup false -os_mon start_disksup false -os_mon start_memsup false -mnesia dir "/usr/local/rabbitmq/var/lib/rabbitmq/mnesia/rabbit@cao" -kernel inet_dist_listen_min 25672 -kernel inet_dist_listen_max 25672
cao 9925 7109 0 16:03 pts/1 00:00:00 grep --color=auto rabbitmq [cao@cao sbin]$ kill -9 8872 8997 (根据实际进程id)
问题解决
另起一个窗口,启动控制台:
[cao@cao 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@cao... started 6 plugins.
有上述结果表示启动成功,如果这边有报错:
Error: The following plugins could not be found:
rabbitmq_management
这样的话可能是路径没有找到,参考以下方法解决,在/usr/local/rabbitmq/sbin目录下修改rabbitmq-env文件,在该文件最后加:
RABBITMQ_MNESIA_BASE=/usr/local/rabbitmq/data
RABBITMQ_LOG_BASE=/usr/local/rabbitmq/log
RABBITMQ_PLUGINS_DIR=/usr/local/rabbitmq/plugins
然后重启rabbitmq服务进行解决
增加rabbitmq的管理用户,方便进行远程登录,同样在sbin目录下执行:
[cao@cao sbin]$ ./rabbitmqctl add_user cao 123456
Creating user "cao" ...
[cao@cao sbin]$ ./rabbitmqctl set_user_tags cao administrator
Setting tags for user "cao" to [administrator] ...
接下来需要设置用户的权限,设置后才能进行创建exchange或者queue ,可以用命令也可以登录到界面上进行操作,先说命令的方法,界面操作的放在【问题记录】里:
/代表Virtual host ,cao是用户名
[cao@cao sbin]$ rabbitmqctl set_permissions -p / cao ".*" ".*" ".*"
Setting permissions for user "cao" in vhost "/" ...
查看用户权限:
[cao@cao sbin]$ ./rabbitmqctl list_user_permissions cao
Listing permissions for user "cao" ...
/ .* .* .*
打开浏览器访问网址 http://IP:15672/#/queues,使用上步设置的用户名cao,密码123456即可登录:
到此单节点的rabbitmq服务器搭建完成
我在安装ncurses时遇到问题:
原因是builder是rpm的用户,缺少就报错,也可以不用管,解决方法是:增加用户builder:
[root@cao sbin]# useradd builder
网址登录rabbitmq时可以,但是新建exchange和queue时报错:User not authorised to access virtual host
这是因为没有给用户设置权限的问题,上面3.3提到命令设置,这里说下界面操作,首先使用用户名cao 密码123456登录界面,点击admin栏:
点击用户名,进入permissions,选择Virtual host,最后点击set permission:
这样就可以继续创建exchange和queue了