RabbitMQ配置

文章目录

centos7安装rabbitmq
官网教程:https://www.rabbitmq.com/install-rpm.html#downloads

官网介绍了两种安装方法:

安装使用yum库中的包(强烈建议此选项)上Cloudsmith.io或PackageCloud

下载软件包并使用rpm安装它。此选项将需要手动安装所有软件包依赖项

这里只介绍第二种方法,下载软件包通过rpm安装,软件包依赖项主要指的是erlang

1、下载erlang安装包

由于rabbitmq依赖于erlang,所以要先下载安装erlang,下载安装的erlang和rabbitmq版本要对应,版本要求可以参考官网:https://www.rabbitmq.com/which-erlang.html

下载erlang地址:https://github.com/rabbitmq/erlang-rpm/releases

安装包名称包含el8对应centos8系统,el7对应centos7系统,所以下载时选择包名带有el7的

2、下载rabbitmq安装包

下载地址:https://github.com/rabbitmq/rabbitmq-server/releases

注意与erlang版本对应

将下载的两个安装包放到Linux服务器,建议路径:/usr/local/software(software文件夹需要自己创建)

如果上传失败,可能是文件夹权限问题,修改文件夹权限:

shell 复制代码
chmod 777 /usr/local/software

3、安装erlang和rabbitmq

shell 复制代码
rpm -ivh erlang-23.3.4.8-1.el7.x86_64.rpm # 安装erlang
yum install socat -y # 安装所需依赖
rpm -ivh rabbitmq-server-3.9.11-1.el7.noarch.rpm # 安装rabbitmq

rpm默认安装在/usr/lib目录下,至此,rabbitmq就安装完成了

启动rabbitmq

设置开机启动

shell 复制代码
chkconfig rabbitmq-server on
启动服务

/sbin/service rabbitmq-server start
查看服务状态

/sbin/service rabbitmq-server status
停止服务

/sbin/service rabbitmq-server stop

如果启动服务报错:

shell 复制代码
Job for rabbitmq-server.service failed because the control process exited with 
error code. See "systemctl status rabbitmq-server.service" and "journalctl -xe" for details.

参考解决方案:https://blog.csdn.net/fvdfsdafdsafs/article/details/89332506

浏览器访问rabbitmq

此时浏览器访问:http://ip:15672是失败的,因为没有安装rabbitmq的web插件,安装方法:

shell 复制代码
rabbitmq-plugins enable rabbitmq_management # 安装web插件

安装之前需要把rabbitmq服务停掉,安装完成重启rabbitmq服务才能使插件生效

再次访问,如果还是失败,可能是服务器防火墙没有关闭,查看防火墙状态:

shell 复制代码
systemctl status firewalld
如果防火墙开启,则需要关闭防火墙:

systemctl stop firewalld # 关闭防火墙,只对当前有效,系统重启防火墙还会再次打开
永久关闭防火墙:

systemctl enable firewalld # 系统重启,防火墙也不会再次打开

此时再次访问浏览器就成功了

创建新用户

如果是在Linux浏览器访问本地rabbitmq服务,则使用默认账号(用户名:guest 密码:guest)即可登录成功

如果是在windows浏览器访问,则默认账号登录失败,报错:

User can only log in via localhost # 默认账号没有权限,只能在服务器本地登录

解决方案:创建一个新用户,并赋予管理员权限即可远程登录

Linux浏览器访问rabbitmq服务,使用默认账号登录后可以在图形化界面创建新用户,该方法比较简单,这里介绍通过命令创建新用户

shell 复制代码
rabbitmqctl list_users # 查看当前有哪些用户角色
rabbitmqctl add_user admin 123 # 添加用户(用户名:admin  密码:123)
rabbitmqctl set_user_tags admin administrator # 设置admin用户角色为administrator(超级管理员)

设置用户权限,模板如下:

shell 复制代码
set_permissions [-p <vhostpath>] <user> <conf> <write> <read>
rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*"  # admin用户具有vhostpath为/中所有资源的配

置、写、读权限

相关推荐
初次攀爬者11 小时前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
让我上个超影吧1 天前
消息队列——RabbitMQ(高级)
java·rabbitmq
塔中妖2 天前
Windows 安装 RabbitMQ 详细教程(含 Erlang 环境配置)
windows·rabbitmq·erlang
断手当码农2 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
初次攀爬者2 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端
业精于勤_荒于稀2 天前
物流订单系统99.99%可用性全链路容灾体系落地操作手册
分布式
Ronin3052 天前
信道管理模块和异步线程模块
开发语言·c++·rabbitmq·异步线程·信道管理
Asher05092 天前
Hadoop核心技术与实战指南
大数据·hadoop·分布式
凉凉的知识库2 天前
Go中的零值与空值,你搞懂了么?
分布式·面试·go
?Anita Zhang2 天前
联邦学习实战:如何在分布式场景下构建隐私保护机器学习模型
人工智能·分布式·机器学习