注意:安装完成后建议命令行操作
1.rabbitmqctl参考2.rabbitmq监控相关参考http://john88wang.blog.51cto.com/2165294/1745824
安装(当然也可以apt-get install erlang,只要对版本没要求)
说明:不知道为什么8.4通过以下方法安装,最后make install的时候,看不到安装的文件,诡异,看官网没有源码安装的步骤故,还是按照官网更新源的方法吧
RabbitMQ是基于Erlang的,所以首先必须配置Erlang环境。
从Erlang的官网 下载最新的erlang安装包,我下载的版本是 otp_src_R14B03.tar.gz 。
然后:
$ tar xvzf otp_src_R14B03.tar.gz$ cd otp_src_R14B03$ ./configure
编译后的输出如下图:
提示没有wxWidgets和fop,但是问题不大。继续:
$ make$ sudo make install“By default, Erlang/OTP will be installed in `/usr/local/{bin,lib/erlang}`. To instead install in `<BaseDir>/{bin,lib/erlang}`, use the `--prefix=<BaseDir>` option.”
安装完Erlang,开始安装RabbitMQ-Server。
首先安装依赖包xmlto xsltproc* unzip erlang-nox
主要参考官方文档:
需要安装一个比较新的Python版本。安装略。
需要安装simplejson。从此处下载最新的版本: 。我下载的版本是 simplejson-3.8.1.tar.gz
$ tar xvzf simplejson-3.8.1.tar.gz$ cd simplejson-3.8.1$ sudo python setup.py install
然后安装RabbitMQ Server。从此处下载源代码版本的RabbitMQ:。我下载的版本是 rabbitmq-server-3.5.6.tar.gz
$ tar xvzf rabbitmq-server-3.5.6.tar.gz$ cd rabbitmq-server-3.5.6
$ make# TARGET_DIR=/usr/local SBIN_DIR=/usr/local/sbin MAN_DIR=/usr/local/man make install
在sbin/目录下出现了三个命令:
rabbitmqctl rabbitmq-env rabbitmq-server安装成功。
运行
找到sbin/目录,运行程序:
/usr/local/sbin/rabbitmq-server停止程序:
/usr/local/sbin/rabbitmqctl stop自启动
#!/bin/sh## rabbitmq-server RabbitMQ broker## chkconfig: - 80 05# description: Enable AMQP service provided by RabbitMQ#### BEGIN INIT INFO# Provides: rabbitmq-server# Required-Start: $remote_fs $network# Required-Stop: $remote_fs $network# Default-Start: 2 3 4 5# Default-Stop:# Description: RabbitMQ broker# Short-Description: Enable AMQP service provided by RabbitMQ broker### END INIT INFO# Source function library.. /etc/init.d/functionsexport HOME=/rootPATH=/sbin:/usr/sbin:/bin:/usr/binNAME=rabbitmq-server#DAEMON=/usr/sbin/${NAME}#CONTROL=/usr/sbin/rabbitmqctlDAEMON=/home/software/rabbitmq/sbin/${NAME}CONTROL=/home/software/rabbitmq/sbin/rabbitmqctlDESC=rabbitmq-serverUSER=adminROTATE_SUFFIX=INIT_LOG_DIR=/var/log/rabbitmqPID_FILE=/var/run/rabbitmq/pidSTART_PROG="daemon"LOCK_FILE=/var/lock/subsys/$NAMEtest -x $DAEMON || exit 0test -x $CONTROL || exit 0RETVAL=0set -e[ -f /etc/default/${NAME} ] && . /etc/default/${NAME}ensure_pid_dir () { PID_DIR=`dirname ${PID_FILE}` if [ ! -d ${PID_DIR} ] ; then mkdir -p ${PID_DIR} chown -R ${USER}:${USER} ${PID_DIR} chmod 755 ${PID_DIR} fi}remove_pid () { rm -f ${PID_FILE} rmdir `dirname ${PID_FILE}` || :}start_rabbitmq () { status_rabbitmq quiet if [ $RETVAL = 0 ] ; then echo RabbitMQ is currently running else RETVAL=0 ensure_pid_dir set +e RABBITMQ_PID_FILE=$PID_FILE $START_PROG $DAEMON \ > "${INIT_LOG_DIR}/startup_log" \ 2> "${INIT_LOG_DIR}/startup_err" \ 0<&- & $CONTROL wait $PID_FILE >/dev/null 2>&1 RETVAL=$? set -e case "$RETVAL" in 0) echo SUCCESS if [ -n "$LOCK_FILE" ] ; then touch $LOCK_FILE fi ;; *) remove_pid echo FAILED - check ${INIT_LOG_DIR}/startup_\{log, _err\} RETVAL=1 ;; esac fi}stop_rabbitmq () { status_rabbitmq quiet if [ $RETVAL = 0 ] ; then set +e $CONTROL stop ${PID_FILE} > ${INIT_LOG_DIR}/shutdown_log 2> ${INIT_LOG_DIR}/shutdown_err RETVAL=$? set -e if [ $RETVAL = 0 ] ; then remove_pid if [ -n "$LOCK_FILE" ] ; then rm -f $LOCK_FILE fi else echo FAILED - check ${INIT_LOG_DIR}/shutdown_log, _err fi else echo RabbitMQ is not running RETVAL=0 fi}status_rabbitmq() { set +e if [ "$1" != "quiet" ] ; then $CONTROL status 2>&1 else $CONTROL status > /dev/null 2>&1 fi if [ $? != 0 ] ; then RETVAL=3 fi set -e}rotate_logs_rabbitmq() { set +e $CONTROL rotate_logs ${ROTATE_SUFFIX} if [ $? != 0 ] ; then RETVAL=1 fi set -e}restart_running_rabbitmq () { status_rabbitmq quiet if [ $RETVAL = 0 ] ; then restart_rabbitmq else echo RabbitMQ is not runnning RETVAL=0 fi}restart_rabbitmq() { stop_rabbitmq start_rabbitmq}case "$1" in start) echo -n "Starting $DESC: " start_rabbitmq echo "$NAME." ;; stop) echo -n "Stopping $DESC: " stop_rabbitmq echo "$NAME." ;; status) status_rabbitmq ;; rotate-logs) echo -n "Rotating log files for $DESC: " rotate_logs_rabbitmq ;; force-reload|reload|restart) echo -n "Restarting $DESC: " restart_rabbitmq echo "$NAME." ;; try-restart) echo -n "Restarting $DESC: " restart_running_rabbitmq echo "$NAME." ;; *) echo "Usage: $0 {start|stop|status|rotate-logs|restart|condrestart|try-restart|reload|force-reload}" >&2 RETVAL=1 ;;esacexit $RETVAL
在/etc/init.d 目录下新建一个 rabbitmq-server 文件,
复制上面的内容 添加到 rabbitmq-server 文件里。适当修改 红色部分
DAEMON=/usr/local/sbin/${NAME}
CONTROL=/usr/local/sbin/rabbitmqctlDESC=rabbitmq-serverUSER=rootchmod 755权限,另外debian的functions为:. /lib/lsb/init-functions
chkconfig -add rabbitmq-server自启动,但实测只能启动,关闭不行
配置
主要参考官方文档:
一般情况下,RabbitMQ的默认配置就足够了。如果希望特殊设置的话,有两个途径:
一个是环境变量的配置文件 rabbitmq-env.conf ;一个是配置信息的配置文件 rabbitmq.config;注意,这两个文件默认是没有的,如果需要必须自己创建。
使用
配置远程访问所有node的用户
#用户名与密码$ sudo rabbitmqctl add_user asdf 123456#用户设置为administrator才能远程访问$ sudo rabbitmqctl set_user_tags asdf administrator $ sudo rabbitmqctl set_permissions -p / asdf ".*" ".*" ".*"rabbitmq-env.conf这个文件的位置是确定和不能改变的,位于:/etc/rabbitmq目录下(这个目录需要自己创建)。文件的内容包括了RabbitMQ的一些环境变量,常用的有:#RABBITMQ_NODE_PORT= //端口号#HOSTNAME=RABBITMQ_NODENAME=mqRABBITMQ_CONFIG_FILE= //配置文件的路径RABBITMQ_MNESIA_BASE=/rabbitmq/data //需要使用的MNESIA数据库的路径RABBITMQ_LOG_BASE=/rabbitmq/log //log的路径RABBITMQ_PLUGINS_DIR=/rabbitmq/plugins //插件的路径
具体的列表见:
rabbitmq.config
这是一个标准的erlang配置文件。它必须符合erlang配置文件的标准。它既有默认的目录,也可以在rabbitmq-env.conf文件中配置。文件的内容详见:
监控
主要参考官方文档:
rabbitmq-plugins enable rabbitmq_management
重新启动RabbitMQ,输入 就能够进入到监控页面。默认的用户名和密码是: guest 和 guest。但只能本地访问!如图: