基于Linux安装配置消息队列RabbitMQ

基于Linux安装配置消息队列RabbitMQ的详细过程!


##jdk start 
export JAVA_HOME=/usr/local/jdk1.8.0_231 export CLASSPATH=.:${JAVA_HOME}/jre/lib/rt.jar:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar export PATH=$PATH:${JAVA_HOME}/bin 
##jdk end 


## mavne start MAVEN_HOME=/usr/local/apache-maven-3.6.3 export PATH=${MAVEN_HOME}/bin:${PATH} 
## mavne end 


## erlang start 
ERLANG_HOME=/usr/local/erlang export PATH=${ERLANG_HOME}/bin:${PATH} 
## erland end 


## rabbit start 
RABBITMQ_PATH=/usr/local/rabbitmq/rabbitmq_server-3.10.7 
export PATH=$RABBITMQ_PATH/sbin:$PATH 
## rabbit end

RabbitMQ是一款企业主流的消息队产品,基于Erlang语言的实现使其具有高效的消息处理能力;基于RabbitMQ的高效性以及对消息的可靠性保障,使其在企业中得到了广泛的应用。下面涛哥就来给大家讲一讲RabbitMQ详细的安装配置教程~

一、RabbitMQ介绍

RabbitMQ是一个在AMQP基础上完成的,可复用的企业消息系统。他遵循Mozilla Public License开源协议。

AMQP,即Advanced Message Queuing Protocol, 一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。Erlang中的实现有 RabbitMQ等。

主要特性如下:

  • 保证可靠性:使用一些机制来保证可靠性,如持久化、传输确认、发布确认
  • 灵活的路由功能
  • 可伸缩性:支持消息集群,多台RabbitMQ服务器可以组成一个集群
  • 高可用性:RabbitMQ集群中的某个节点出现问题时队列任然可用
  • 支持多种协议
  • 支持多语言客户端
  • 提供良好的管理界面
  • 提供跟踪机制:如果消息出现异常,可以通过跟踪机制分析异常原因
  • 提供插件机制:可通过插件进行多方面扩展

二、安装前环境准备

  • Linux:CentOS 7.6
  • RabbitMQ:RabbitMQ 3.7

如果之前安装过erlang,请先删除!

yum remove erlang*

基于Linux安装配置消息队列RabbitMQ_第1张图片

安装C++编译环境

# yum -y install make gcc gcc-c++ yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel unixODBC unixODBC-devel httpd python-simplejson yum -y install gcc glibc-devel make ncurses-devel openssl-devel xmlto perl wget gtk2-devel binutils-devel

下载erlang和rabbitMQ

elang - 25.0.3

wget https://github.com/erlang/otp/releases/download/OTP-25.0.3/otp_src_25.0.3.tar.gz

rabbit - 3.10.7

wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.10.7/rabbitmq-server-generic-unix-3.10.7.tar.xz

wget https://github.com/erlang/otp/releases/download/OTP-25.0.3/otp_src_25.0.3.tar.gz

基于Linux安装配置消息队列RabbitMQ_第2张图片

下载RabbitMQ

wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.10.7/rabbitmq-server-generic-unix-3.10.7.tar.xz

基于Linux安装配置消息队列RabbitMQ_第3张图片

三、安装erlang环境

创建/usr/local/erlang目录,我们将erlang安装在此目录。

基于Linux安装配置消息队列RabbitMQ_第4张图片

解压erlang安装包

[root@server-b erlang] tar -xvf /usr/local/src/packer/rb/otp_src_25.0.3.tar.gz tar -xvf /usr/local/src/packer/rb/otp_src_25.0.3.tar.gz

基于Linux安装配置消息队列RabbitMQ_第5张图片

进入解压文件夹 【otp_src_25.0.3/】

[root@server-b erlang]# cd otp_src_25.0.3/ cd otp_src_25.0.3/

erlang编译

erlang需要依赖JDK,因此需要先完成JDK的安装和环境变量配置。指定安装目录及安装配置

[root@server-b otp_src_25.0.3] ./configure --prefix=/usr/local/erlang ./configure --prefix=/usr/local/erlang

基于Linux安装配置消息队列RabbitMQ_第6张图片

编译与安装

[root@server-b otp_src_25.0.3]# make && make install make && make install

基于Linux安装配置消息队列RabbitMQ_第7张图片

基于Linux安装配置消息队列RabbitMQ_第8张图片

配置erlang环境变量

将 export PATH=$PATH:/usr/local/erlang/bin 添加到文件末尾

命令1 vim /etc/profile 命令2 vi /etc/profile 命令3 [root@server-a ~]# sed -i '$aERLANG_PATH=\/usr\/local\/erlang\/bin \nexport=\$ERLANG_PATH:$PATH ' /etc/profile sed -i '$aERLANG_PATH=\/usr\/local\/erlang\/bin \nexport=\$ERLANG_PATH:$PATH ' /etc/profile

基于Linux安装配置消息队列RabbitMQ_第9张图片

重新加载profile文件

## erlang start ERLANG_HOME=/usr/local/erlang export PATH=${ERLANG_HOME}/bin:${PATH} ## erland end

source /etc/profile

验证是否安装成功

[root@server-b /]# erl

四、安装RabbitMQ

4.1 解压RabbitMQ

maker /usr/local/rabbitmq

由于下载的安装包为xz文件,我们先将xz解压为tar。

xz -d rabbitmq-server-generic-unix-3.7.0.tar.xz [root@server-b rabbitmq]# xz -d /usr/local/src/packer/rb/rabbitmq-server-generic-unix-3.10.7.tar.xz

基于Linux安装配置消息队列RabbitMQ_第10张图片

tar -xvf rabbitmq-server-generic-unix-3.7.0.tar [root@server-b rabbitmq]# tar -xvf /usr/local/src/packer/rb/rabbitmq-server-generic-unix-3.10.7.tar

基于Linux安装配置消息队列RabbitMQ_第11张图片

添加配置文件

[root@server-b rabbitmq_server-3.10.7]# vim /etc/profile

[root@server-b rabbitmq_server-3.10.7]# source /etc/profile

命令1

sed -i '$aRABBITMQ_PATH=\/usr\/local\/rabbitmq\/sbin

\nexport PATH=\$RABBITMQ_PATH:$PATH ' /etc/profile

命令2

## rabbit

RABBITMQ_PATH=/usr/local/rabbitmq/rabbitmq_server-3.10.7

export PATH=$RABBITMQ_PATH/sbin:$PATH

##

基于Linux安装配置消息队列RabbitMQ_第12张图片

source /etc/profile

4.2 启动RabbitMQ

进入到解压的RabbitMQ的sbin目录

cd rabbitmq_server-3.7.0/sbin

[root@server-b rabbitmq_server-3.10.7]# pwd /usr/local/rabbitmq/rabbitmq_server-3.10.7 [root@server-b rabbitmq_server-3.10.7]# [root@server-b rabbitmq_server-3.10.7]# cd sbin/

启动RabbitMQ

[root@server-b sbin]#

./rabbitmq-server detached

./rabbitmq-server -detached

./rabbitmq-server detached

基于Linux安装配置消息队列RabbitMQ_第13张图片

查看进程,RabbitMQ的默认端口是5672

# 启动rabbitmq

# rabbitmq-server –detached

# 查看状态

#[root@server-b sbin] .rabbitmqctl status

# rabbitmqctl status

# 停止

# rabbitmqctl stop

# 查看进程 # ps -ef | grep rabbitmq

# 开启web插件

# rabbitmq-plugins enable rabbitmq_management

# 浏览器访问 ip:15672

# 默认账号密码:guest guest(这个账号只允许本机访问)

启动命令1

[root@server-b sbin]# /usr/local/rabbitmq/rabbitmq_server-3.10.7/sbin/rabbitmq-server start

启动命令2

[root@server-b sbin]# /usr/local/rabbitmq/rabbitmq_server-3.10.7/sbin/rabbitmq-server start 1>/dev/null

后台启动命令: [root@server-b sbin]# ./rabbitmq-server -detached

关闭命令1:

[root@server-b sbin]# /usr/local/rabbitmq/rabbitmq_server-3.10.7/sbin/rabbitmq-server stop

[root@server-b sbin]# /usr/local/rabbitmq/rabbitmq_server-3.10.7/sbin/rabbitmq-server stop 1>/dev/null

lsof -i:5672 # 或者 ps aux|grep rabbit #ps a 显示现行终端机下的所有程序,包括其他用户的程序。

#ps u   以用户为主的格式来显示程序状况。

#ps x   显示所有程序,不以终端机来区分。

# 创建rabbitmq用户账号

# 查看所有用户 rabbitmqctl list_users

# 添加用户 rabbitmqctl add_user admin 123456

# 配置权限 rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*"

# 查看用户权限 rabbitmqctl list_user_permissions admin

# 设置tag rabbitmqctl set_user_tags admin administrator

# 删除用户 rabbitmqctl delete_user guest

五、启动RabbitMQ管理系统

启动RabbitMQ的管理系统插件(需进入sbin目录)

[root@server-b sbin]# ./rabbitmq-plugins enable rabbitmq_management

./rabbitmq-plugins enable rabbitmq_management

 访问管理系统:http://ip:15672/

你可能感兴趣的:(ruby,开发语言,后端)