注意:安装完成后建议命令行操作

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/rabbitmqctl
DESC=rabbitmq-server
USER=root

chmod 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=mq
RABBITMQ_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。但只能本地访问!如图: