【RabbitMQ(day1)】RabbitMQ的概述和安装

入门RabbitMQ

一、RabbitMQ的概述

MQ(Message Queue)翻译为消息队列,通过典型的【生产者】和【消费者】模型,生产者不断向消息队列中生产消息,消费者不断地从队列中获取消息。因为消息的生产和消费都是异步的,而且只关心消息的发送和接收,没有业务逻辑的侵入,轻松的实现系统间的解耦。别名为 消息中间件; 通过利用高效可靠的消息传递机制来进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成。

常见的MQ中间件:老牌的 ActiveMQ、RabbitMQ,炙手可热的 Kafka,阿里巴巴自主研发的RocketMQ等。

RabbitMQ:RabbitMQ 是使用 Erlang 语言开发的开源消息队列系统,基于AMQP协议来实现 。AMQP的主要特征是面向消息、队列、路由(包括点对点和发布/订阅)、可靠性、安全。AMQP协议更多用在企业系统内对数据一致性、稳定性和可靠性要求更高的场景,对性能和吞吐量的要求还在其次。

RabbitMQ的四大核心:生产者、消费者、队列、交换机。

AMQP(Advanced Message Queue Protocol 高级消息队列协议)是一种二进制协议,它定义了一组规则和标准,以确保消息可以在不同的应用程序和平台之间传递和解释,AMQP协议包含下面四大核心组件:消息、交换机、队列、绑定。

下面是AMQP的模型图:

二、RabbitMQ的安装

RabbitMQ下载网址(3.8.16版本):地址

对应的erlang下载网址(erlang-23.3.4.11-1):地址

下载好后移至Centos中

  1. 安装erlang
bash 复制代码
rpm -ivh erlang-23.3.4-1.el7.x86_64.rpm
  1. 安装一个socat插件
bash 复制代码
yum install socat -y
  1. 安装Rabbit服务
bash 复制代码
rpm -ivh rabbitmq-server-3.8.16-1.el7.noarch.rpm
  1. 设置开启自动开启rabbit-server
bash 复制代码
chkconfig rabbitmq-server on
  1. 启动rabbitmq服务
bash 复制代码
service rabbitmq-server start
  1. 查看rabbitmq服务状态
bash 复制代码
service rabbitmq-server status
  1. 停止服务;开启web管理插件。
bash 复制代码
service rabbitmq-server stop
rabbitmq-plugins enable rabbitmq_management
  1. 再次开启服务访问web页面(默认端口号是15672),记得关防火墙。

  2. 创建新用户(创建账号)

bash 复制代码
rabbitmqctl add_user admin 123456
  1. 设置用户角色
bash 复制代码
rabbitmqctl set_user_tags admin administrator
  1. 设置用户权限
bash 复制代码
rabbitmqctl set_permissions -p "/" admin ".*" ".*" ".*"
# 即admin用户具有/vhost1这个virtual host 中所有的配置,写、读权限
  1. 显示所有用户,尝试使用admin用户去登录。
bash 复制代码
rabbitmqctl list_users

登录成功的界面(RabbitMQ的管理界面)

三、RabbitMQ管理命令行

bash 复制代码
# 服务启动相关
systemctl start|restart|stop|status rabbitmq-server

# 管理命令行  用来在不适用web管理界面的情况下命令操作RabbitMQ
rabbitmqctl help  可以查看更多命令

# 插件管理命令行
rabbitmqplugins enable|list|disable

四、RabbitMQ的GUI界面

当前RabbitMQ服务的概述界面.

连接界面展示,此时的连接为0.

通道界面展示,此时通道数也为0.
交换机操作界面

队列操作界面.

用户的操作界面.

相关推荐
长安城没有风4 小时前
从入门到精通【Redis】Redis 典型应⽤ --- 分布式锁
数据库·redis·分布式
爬山算法7 小时前
Redis(69)Redis分布式锁的优点和缺点是什么?
数据库·redis·分布式
virtuousOne13 小时前
Kafka基础
分布式·kafka
虫小宝13 小时前
Java分布式架构下的电商返利APP技术选型与架构设计实践
java·分布式·架构
007php00713 小时前
百度面试题解析:Zookeeper、ArrayList、生产者消费者模型及多线程(二)
java·分布式·zookeeper·云原生·职场和发展·eureka·java-zookeeper
waving-black14 小时前
windows系统下安装测试kafka
windows·分布式·kafka
深思慎考14 小时前
RabbitMQ 入门:基于 AMQP-CPP 的 C++ 实践指南与二次封装
开发语言·c++·分布式·rabbitmq·api
Mr.456714 小时前
RabbitMQ消息传输中Protostuff序列化数据异常的深度解析与解决方案
rabbitmq
深思慎考14 小时前
Ubuntu 系统 RabbitMQ 安装指南与使用(含 C++ 客户端与 SSL 错误解决)
c++·ubuntu·rabbitmq·github·rabbitmqpp
Andya_net14 小时前
Java | 基于redis实现分布式批量设置各个数据中心的服务器配置方案设计和代码实践
java·服务器·分布式