美文网首页
CentOS 7 安装 RabbitMQ

CentOS 7 安装 RabbitMQ

作者: 萧萧飞叶 | 来源:发表于2019-03-09 04:12 被阅读0次
开放防火墙端口

$ firewall-cmd --zone=public --add-port=5672/tcp --permanent

$ firewall-cmd --zone=public --add-port=15672/tcp --permanent

$ firewall-cmd --zone=public --add-port=25672/tcp --permanent

$ firewall-cmd --zone=public --add-port=4369/tcp --permanent

$ sudo firewall-cmd --reload

方法一:步骤安装

1、创建目录

$ mkdir -p /usr/java

$ cd /usr/java

2、安装erlang

erlang在安装前需要先安装下它的依赖工具:

$ sudo yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel unixODBC-devel

官网下载 erlang源码包,或者用wget获取:

$ wget http://erlang.org/download/otp_src_21.2.tar.gz

$ tar -xvzf otp_src_21.2.tar.gz

$ cd otp_src_21.2

$ ./configure --prefix=/usr/java/erlang --without-javac

--prefix=/usr/erlang 是说明将当前的安装放在usr/erlang文件夹下。

$ make

$ make install

安装 make install 。安装完成后会有一个erlang文件夹。otp_src_21.2和otp_src_21.2.tar.gz都可以删除了。

测试:$ ./bin/erl

3、配置环境变量

$ sudo vi /etc/profile

# erlang env
export ERLANG_HOME=/usr/java/erlang/
export PATH=$ERLANG_HOME/bin:$PATH

$ source /etc/profile

4、使用编译过的包安装rabbitmq

$ wget https://dl.bintray.com/rabbitmq/all/rabbitmq-server/3.7.11/rabbitmq-server-generic-unix-3.7.11.tar.xz

$ xz -d rabbitmq-server-generic-unix-3.7.11.tar.xz
$ tar -xvf rabbitmq-server-generic-unix-3.7.11.tar
$ mv rabbitmq_server-3.7.11/ rabbitmq

  • 设置环境变量
    $ vi /etc/profile
# Rabbitmq Env
export RABBITMQ_HOME=/usr/java/rabbitmq
export PATH=$PATH:${RABBITMQ_HOME}/sbin

$ source /etc/profile

  • 配置
    在./sbin/rabbitmq-defaults 文件中,CONFIG_FILE变量指定了配置文件的位置,CONF_ENV_FILE指定了rabbitmq-env.conf文件的位置
CONFIG_FILE=/usr/java/rabbitmq/etc/rabbitmq/rabbitmq
CONF_ENV_FILE=/usr/java/rabbitmq/etc/rabbitmq/rabbitmq-env.conf

按照位置创建配置文件:$ touch /usr/java/rabbitmq/etc/rabbitmq/rabbitmq.config
rabbitmq.config内容范例
按照位置创建配置文件:$ touch /usr/java/rabbitmq/etc/rabbitmq/rabbitmq-env.conf
rabbitmq-env.conf内容:

RABBITMQ_MNESIA_BASE=/usr/java/rabbitmq/data
RABBITMQ_LOG_BASE=/usr/java/rabbitmq/logs

$ mkdir -p /usr/java/rabbitmq/data
$ mkdir -p /usr/java/rabbitmq/logs

启动:$ rabbitmq-server
开启web管理插件:$ rabbitmq-plugins enable rabbitmq_management

登录遇到问题:User can only log in via localhost
找到rabbit.app vi /usr/rabbitmq/ebin/rabbit.app

将:{loopback_users, [<<”guest”>>]},
改为:{loopback_users, []},
  • 添加到服务
    脚本见末尾 或 参考
    出现问题服务启动不了
    $ cat /var/log/rabbitmq/startup_err
[root@centos-100 panqt]# cat /var/log/rabbitmq/startup_err
/usr/java/rabbitmq/sbin/rabbitmq-server:行187: erl: 未找到命令

因为脚本中没有导入erlang环境变量,导入即可

方法二:配置yum源式安装

$ vi /etc/yum.repos.d/rabbitmq-erlang.repo

[rabbitmq-erlang]
name=rabbitmq-erlang
baseurl=https://dl.bintray.com/rabbitmq/rpm/erlang/21/el/7
gpgcheck=1
gpgkey=https://dl.bintray.com/rabbitmq/Keys/rabbitmq-release-signing-key.asc
repo_gpgcheck=0
enabled=1

$ vi /etc/yum.repos.d/rabbitmq-server.repo

[bintray-rabbitmq-server]
name=bintray-rabbitmq-rpm
baseurl=https://dl.bintray.com/rabbitmq/rpm/rabbitmq-server/v3.7.x/el/7/
gpgcheck=0
repo_gpgcheck=0
enabled=1

显示可安装的程序包:

$ yum list available rabbitmq-server

$ yum list available erlang

安装:$ yum install -y rabbitmq-server

一个命令就可以把erlang和rabbitmq都安装好

yum源式安装配置:

$ cd /etc/rabbitmq

$ vi rabbitmq-env.conf

RABBITMQ_MNESIA_BASE=/usr/rabbitmq/rabbitmq-server/data
RABBITMQ_LOG_BASE=/usr/rabbitmq/rabbitmq-server/logs

$ mkdir -p /usr/rabbitmq/rabbitmq-server/data

$ mkdir -p /usr/rabbitmq/rabbitmq-server/logs

$ chmod -R 777 /usr/rabbitmq

对于rabbitmq.config配置文件的样本可以在/usr/share/doc/rabbitmq-server/ 或者 /usr/share/doc/rabbitmq-server-3.7.13/里找到,就是一个rabbitmq.config.example的文件,去掉.example即可使用,RabbitMQ平时使用默认配置即可

$ cp /usr/share/doc/rabbitmq-server-3.7.13/rabbitmq.config.example /etc/rabbitmq/rabbitmq.config

然后保存安装下RabbitMQ服务

$ rabbitmq-server install

启动RabbitMQ服务可以通过命令:$ rabbitmq-server start

添加rabbitmq到启动项可以通过命令:$ chkconfig rabbitmq-server on

还有就是开启管理界面可以通过命令:$ rabbitmq-plugins enable rabbitmq_management

访问管理服务:http://192.168.200.100:15672/

出现错误:User can only log in via localhost


解决办法:https://blog.csdn.net/shenhonglei1234/article/details/82745601
服务脚本:
#!/bin/sh
# chkconfig: 2345 80 05
# rabbitmq-server RabbitMQ broker

 
# Source function library.
. /etc/init.d/functions
export HOME=/root
ERLANG_HOME=/usr/java/erlang
PATH=${ERLANG_HOME}/bin:$PATH


DAEMON=/usr/java/rabbitmq/sbin/rabbitmq-server
CONTROL=/usr/java/rabbitmq/sbin/rabbitmqctl

USER=root
ROTATE_SUFFIX=
INIT_LOG_DIR=/usr/java/rabbitmq/log
PID_FILE=/var/run/rabbitmq/pid
 
START_PROG="daemon"
LOCK_FILE=/var/lock/subsys/rabbitmq-server
 
test -x $DAEMON || exit 0
test -x $CONTROL || exit 0
 
RETVAL=0
set -e
 
[ -f /etc/default/rabbitmq-server ] && . /etc/default/rabbitmq-server
 
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
}
ensure_init_log_dir () {
    if [ ! -d ${INIT_LOG_DIR} ] ; then
        mkdir -p ${INIT_LOG_DIR}
        chown -R ${USER}:${USER} ${INIT_LOG_DIR}
        chmod 755 ${INIT_LOG_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
        ensure_init_log_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 rabbitmq-server: "
        start_rabbitmq
        echo "rabbitmq-server."
        ;;
    stop)
        echo -n "Stopping rabbitmq-server: "
        stop_rabbitmq
        echo "rabbitmq-server."
        ;;
    status)
        status_rabbitmq
        ;;
    rotate-logs)
        echo -n "Rotating log files for rabbitmq-server: "
        rotate_logs_rabbitmq
        ;;
    force-reload|reload|restart)
        echo -n "Restarting rabbitmq-server: "
        restart_rabbitmq
        echo "rabbitmq-server."
        ;;
    try-restart)
        echo -n "Restarting rabbitmq-server: "
        restart_running_rabbitmq
        echo "rabbitmq-server."
        ;;
    *)
        echo "Usage: $0 {start|stop|status|rotate-logs|restart|condrestart|try-restart|reload|force-reload}" >&2
        RETVAL=1
        ;;
esac
 
exit $RETVAL

搭建集群:RabbitMQ 集群

参考:CentOS7.2中安装rabbitmq
配置:rabbitmq.config.example

相关文章

网友评论

      本文标题:CentOS 7 安装 RabbitMQ

      本文链接:https://www.haomeiwen.com/subject/ecmjpqtx.html