云服务器 ECS 建站教程:部署RabbitMQ

简介:


部署RabbitMQ


RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种客户端,如:Python、Ruby、.NET、Java、JMS、C、PHP、ActionScript、XMPP、STOMP 等,支持 AJAX。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

部署方式

在阿里云服务器下部署 RabbitMQ 提供两种部署方式:

  • RabbitMQ 镜像部署
  • 手动部署(源码编译安装)

一般推荐镜像部署适合新手使用更加快捷方便,安装包部署以及手动部署适合对 Linux 命令有基本了解的用户,可以满足用户个性化部署的要求。本教程主要介绍镜像和手工部署的方式。

镜像部署

1.单击 RabbitMQ 环境 ( CentOS7.3 Erlang19.3 ) 进入镜像详情页。

2.单击 立即购买,按提示步骤购买 ECS 实例。

3.登录 ECS 管理控制台。

4.在左边导航栏里,单击 实例,进入 ECS 实例列表页。

5.选择所购 ECS 实例所在的地域,并找到所购 ECS 实例,在 IP 地址 列获取该实例的公网 IP 地址。

6.在浏览器地址栏中输入公网 IP 地址,下载操作文档。


image


7.使用 putty 登录 Linux 服务器,请参考连接Linux实例;忘记 root 密码,请参考重置实例密码。

8.初始化 rabbitmq。

 cd /root/oneinstack
 ./init_rabbitmq.sh


image


9.进入管理页面,浏览器访问 http://公网IP:15672 。


image


手工部署

  • 系统平台:CentOS 7.3
  • rabbitmq版本:rabbitmq-server -3.6.9
  • erlang版本:erlang19.3
  • JDK版本:JDK1.8.0_121

前提准备

创建一般用户 rabbitmq,运行 rabbitmq。

useradd rabbitmq

设置 Linux 主机名。

centos 7 修改 /etc/hostname,centos6 修改 /etc/sysconfig/network,下面以 centos 7 为例:

echo rabbit1 > /etc/hostname
hostname rabbit1
exit  #退出重新登录


image


安装依赖包

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


image


源代码下载

wget http://erlang.org/download/otp_src_19.3.tar.gz
wget https://www.rabbitmq.com/releases/rabbitmq-server/v3.6.9/rabbitmq-server-generic-unix-3.6.9.tar.xz

安装 Erlang

tar xzf otp_src_19.3.tar.gz #解压
cd otp_src_19.3
./configure --prefix=/usr/local/erlang --enable-shared-zlib --with-ssl --enable-threads --enable-smp-support --enable-kernel-poll --enable-hipe --without-javac
make && make install

解压 RabbitMQ

1.解压 rabbitmq-server-generic-unix-3.6.9.tar.xz 。

tar xvJf rabbitmq-server-generic-unix-3.6.9.tar.xz
mv rabbitmq_server-3.6.9  /usr/local/rabbitmq

2.rabbitmq 环境变量配置。

sed -i 's@^ERL_DIR=.*@ERL_DIR=/usr/local/erlang/bin/@' /usr/local/rabbitmq/sbin/rabbitmq-defaults
sed -i 's@^LOG_BASE=.*@LOG_BASE=/usr/local/rabbitmq/var/log/rabbitmq@' /usr/local/rabbitmq/sbin/rabbitmq-defaults
mkdir -p /usr/local/rabbitmq/var/{lib,log}/rabbitmq

3.一般用户(rabbitmq)运行 RabbitMQ。

wget http://pkgs.fedoraproject.org/cgit/rpms/rabbitmq-server.git/plain/rabbitmq-script-wrapper
sed -i 's@cd /var/lib/rabbitmq@cd /usr/local/rabbitmq/var/lib/rabbitmq@g' rabbitmq-script-wrapper  #更改rabbitmq数据存储目录
sed -i 's@/usr/lib/rabbitmq/bin/@/usr/local/rabbitmq/sbin/@g' rabbitmq-script-wrapper
chmod +x rabbitmq-script-wrapper
cp rabbitmq-script-wrapper /usr/sbin/rabbitmqctl
cp rabbitmq-script-wrapper /usr/sbin/rabbitmq-server
cp rabbitmq-script-wrapper /usr/sbin/rabbitmq-plugins
chown -R rabbitmq.rabbitmq /usr/local/rabbitmq/var

4.rabbitmq 日志割接。

cat >> /etc/logrotate.d/rabbitmq-server << EOF
/usr/local/rabbitmq/var/log/rabbitmq/*.log {
weekly
missingok
rotate 20
compress
delaycompress
notifempty
sharedscripts
postrotate
 /sbin/service rabbitmq-server rotate-logs > /dev/null
endscript
}
EOF

5.rabbitmq 启动脚本。

vi /etc/init.d/rabbitmq-server
#!/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
# Description:       RabbitMQ broker
# Short-Description: Enable AMQP service provided by RabbitMQ broker
### END INIT INFO
# Source function library.
. /etc/init.d/functions
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/local/erlang/bin
NAME=rabbitmq-server
DAEMON=/usr/sbin/${NAME}
CONTROL=/usr/sbin/rabbitmqctl
DESC=rabbitmq-server
USER=rabbitmq
ROTATE_SUFFIX=
INIT_LOG_DIR=/usr/local/rabbitmq/var/log/rabbitmq
PID_FILE=/var/run/rabbitmq/pid
START_PROG="daemon"
LOCK_FILE=/var/lock/subsys/$NAME
test -x $DAEMON || exit 0
test -x $CONTROL || exit 0
RETVAL=0
set -e
[ -f /etc/default/${NAME} ] && . /etc/default/${NAME}
[ -f /etc/sysconfig/${NAME} ] && . /etc/sysconfig/${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
     # RABBIT_NOFILES_LIMIT from /etc/sysconfig/rabbitmq-server is not handled
     # automatically
     if [ "$RABBITMQ_NOFILES_LIMIT" ]; then
             ulimit -n $RABBITMQ_NOFILES_LIMIT
     fi
     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
     ;;
esac
exit $RETVAL

保存后,添加执行权限,并设置自启动。

chmod +x /etc/init.d/rabbitmq-server
chkconfig --add rabbitmq-server
chkconfig rabbitmq-server on

6.修改 rabbitmq.config 。

特别注意默认用户名密码,请自行修改 default_user,default_pass,loopback_users。

cat > /usr/local/rabbitmq/etc/rabbitmq/rabbitmq.config << EOF
[
{rabbit, [
 {tcp_listeners,[{"0.0.0.0",5672}]},
 {tcp_listen_options, [binary, {packet,raw},
                               {reuseaddr,true},
                               {backlog,128},
                               {nodelay,true},
                               {exit_on_close,false},
                               {keepalive,true}]},
 {default_vhost,       <<"/">>},
 {default_user,        <<"guest">>},
 {default_pass,        <<"guest">>},
 {loopback_users, ["guest"]},
 {default_permissions, [<<".*">>, <<".*">>, <<".*">>]}
]}
].
EOF

7.开启 rabbitmq manager。

cat > /usr/local/rabbitmq/etc/rabbitmq/enabled_plugins << EOF
[rabbitmq_management].
EOF

8.启动 rabbitmq 。

service rabbitmq-server start


image


9.进入管理页面。

浏览器访问 http://公网IP:15672。


image

更多开源软件尽在云市场:https://market.aliyun.com/software

原文链接

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
11天前
|
负载均衡 应用服务中间件 持续交付
微服务架构下的Web服务器部署
【8月更文第28天】随着互联网应用的不断发展,传统的单体应用架构逐渐显露出其局限性,特别是在可扩展性和维护性方面。为了解决这些问题,微服务架构应运而生。微服务架构通过将应用程序分解成一系列小型、独立的服务来提高系统的灵活性和可维护性。本文将探讨如何在微服务架构中有效部署和管理Web服务器实例,并提供一些实际的代码示例。
38 0
|
5天前
|
网络协议 网络安全
基于bind软件部署DNS服务器
关于如何使用bind软件部署DNS服务器的教程,包括DNS服务器的类型、基于bind软件的部署步骤、验证DNS服务器可用性的指导,以及如何进行DNS正向解析的实现。
10 2
基于bind软件部署DNS服务器
|
6天前
|
存储 关系型数据库 MySQL
使用Docker快速部署Mysql服务器
本文介绍了如何使用Docker快速部署MySQL服务器,包括下载官方MySQL镜像、启动容器、设置密码、连接MySQL服务器以及注意事项。
66 18
|
12天前
|
JavaScript NoSQL 中间件
《Node.js后端修炼手册》——揭秘服务器搭建与部署上线的生死时速,让你一战成名!
【8月更文挑战第27天】本文详细介绍如何从零开始利用Node.js构建后端服务器并部署至生产环境。首先,通过简易步骤搭建基础服务器,包括环境安装与配置。接着,引入Express框架优化路由与中间件管理,提升开发效率。随后,利用Mongoose实现MongoDB数据库连接,增强数据交互能力。为保证系统稳定性,文中还讲解了错误处理机制。最后,通过PM2等工具部署应用至生产环境,确保高效运行。本教程辅以示例代码,帮助读者快速掌握Node.js后端开发全流程。
48 2
|
8天前
|
UED
JSF文件下载:解锁终极文件传输秘籍,让你的Web应用瞬间高大上!
【8月更文挑战第31天】掌握JSF文件下载功能对构建全面的Web应用至关重要。本文通过具体代码示例,详细介绍如何在JSF中实现文件下载。关键在于后端Bean中的文件读取与响应设置。示例展示了从创建实体类到使用`&lt;h:commandLink&gt;`触发下载的全过程,并通过正确设置响应头和处理文件流,确保文件能被顺利下载。这将显著提升Web应用的实用性与用户体验。
20 0
|
8天前
|
Java 数据库 API
JSF与JPA的史诗级联盟:如何编织数据持久化的华丽织锦,重塑Web应用的荣耀
【8月更文挑战第31天】JavaServer Faces (JSF) 和 Java Persistence API (JPA) 分别是构建Java Web应用的用户界面组件框架和持久化标准。结合使用JSF与JPA,能够打造强大的数据驱动Web应用。首先,通过定义实体类(如`User`)和配置`persistence.xml`来设置JPA环境。然后,在JSF中利用Managed Bean(如`UserBean`)管理业务逻辑,通过`EntityManager`执行数据持久化操作。
16 0
|
8天前
|
JavaScript 搜索推荐 前端开发
从零搭建到部署:Angular与Angular Universal手把手教你实现服务器端渲染(SSR),全面解析及实战指南助你提升Web应用性能与SEO优化效果
【8月更文挑战第31天】服务器端渲染(SSR)是现代Web开发的关键技术,能显著提升SEO效果及首屏加载速度,改善用户体验。Angular Universal作为官方SSR解决方案,允许在服务器端生成静态HTML文件。本文通过具体示例详细介绍如何使用Angular Universal实现SSR,并分享最佳实践。首先需安装Node.js和npm。
12 0
|
2月前
|
消息中间件 C语言 RocketMQ
消息队列 MQ操作报错合集之出现"Connection reset by peer"的错误,该如何处理
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
|
2月前
|
消息中间件 Java C语言
消息队列 MQ使用问题之在使用C++客户端和GBase的ESQL进行编译时出现core dump,该怎么办
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
|
21天前
|
消息中间件 存储 Java
【揭秘】RocketMQ内部运作大揭秘:一探究竟,原来消息队列是这样工作的!
【8月更文挑战第19天】RocketMQ是一款高性能、高可用的消息中间件,在分布式系统中至关重要。它采用发布/订阅模式,支持高吞吐量的消息传递。核心组件包括管理元数据的NameServer、存储消息的Broker以及Producer和Consumer。RocketMQ支持发布/订阅与点对点两种模型,并具备复杂的消息持久化和路由机制。通过Java API示例,可轻松实现消息的发送与接收。RocketMQ凭借其出色的特性和可靠性,成为大型分布式系统首选的消息解决方案。
45 5