RabbitMQ安装

1.RabbitMQ安装

1.1什么是MQ?

MQ(Message Quene):消息队列,通过典型的生产者和消费者模型不断向消息队列中生产消息,消费者不断从队列中获取消息。因为消息的生产和消费是异步的,而且只关系消息的发送和接收,没有业务逻辑的侵入,轻松地实现系统间解耦。别名为消息中间件,通过利用高效可靠的消息传递机制进行平台无关的数据交流,并给予数据通信进行分布式系统的集成。
在这里插入图片描述

1.2什么是RabbitMQ?

RabbitMQ是一套开源(MPL)的消息队列服务软件,是由 LShift 提供的一个 Advanced Message Queuing Protocol (AMQP) 的开源实现,由以高性能、健壮以及可伸缩性出名的 Erlang 写成。

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开放电信平台框架上的。所有主要的编程语言均有与代理接口通讯的客户端库。

1.3AMQP协议

AMQP(advanced message queuing protocol)在2003年时被提出,最早用于解决金融领不同平台之间的消息传递交互问题。顾名思义,AMQP是一种协议,更准确的说是一种binary wire-level protocol(链接协议)。这是其和JMS的本质差别,AMQP不从API层进行限定,而是直接定义网络交换的数据格式。这使得实现了AMQP的provider天然性就是跨平台的。以下是AMQP协议模型:
在这里插入图片描述
在这里插入图片描述

1.4不同MQ的特点

  • ActiveMQ:是Apache出品,是最流行,能力强劲的开源消息总线。它是一个完全支持JMS规范的消息中间件。有丰富的API,多种集群架构模式让ActiveMQ称为老牌成熟的消息中间件,中小企业使用广泛

  • Kafka:是LinkedIn开源的分布式发布-订阅消息系统,目前属于Apache顶级项目。主要特点是基于Pull的模式处理消息消费,追求吞吐量。一开始的目的就是用于日志收集和传输,0.8版本之后开始支持复制,不支持事务,对消息的重复、丢失、错误没有严格要求,适合产生大量数据的互联网服务的数据收集业务

  • RocketMQ:是阿里开源的消息中间件,纯java开发,具有高吞吐量、高可用性、适合大规模分布式系统应用的特点。RocketMQ起源于Kafka,对消息的可靠传输及事务性做了优化,在阿里被广泛用于交易、充值、流计算、消息推送、日志流式处理、binglog分发等场景

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

RabbitMQ比Kafka更可靠,Kafka更适合IO高吞吐的处理,一般应用在大数据日志处理或对实时性(少量延迟),可靠性(少量丢失数据)要求稍低的场景使用,比如ELK日志收集

1.5RabbitMQ的安装

1.5.1RabbitMQ的官网

在这里插入图片描述

1.5.2下载安装包

我的虚拟机是centOS,选择适合自己版本的安装包下载
在这里插入图片描述
在这里插入图片描述

1.5.3下载安装包,放入Linux文件夹

在这里插入图片描述

1.5.4解压

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

1.5.5查看版本信息

在这里插入图片描述在RabiitMQ安装过程中需要依赖socat插件,首先安装该插件

1.5.6下载socat

在这里插入图片描述

1.5.7安装rabbit MQ

在这里插入图片描述
在这里插入图片描述

1.5.8安装完成,设置主机的主机名于ip地址的映射关系

编辑/etc/hosts

在这里插入图片描述

1.5.9重启一下rabbitmq

重启Rabbitmq
systemctl restart rabbitmq-server

查看一下状态防火墙状态
systemctl status firewalld
在这里插入图片描述

1.5.10安装web管理的插件

rabbitmq-plugins enable rabbitmq_management

在浏览器登录,默认端口号:15672
ip地址+端口号

1.5.11设置一个用户

添加用户(用户admin,密码admin)

rabbitmqctl add_user admin admin

设置用户角色(admin为管理员)

rabbitmqctl set_user_tags admin administrator

设置用户权限(接受来自所有Host的所有操作)

rabbitmqctl set_permissions -p "/" admin '.*' '.*' '.*'

查看用户权限

rabbitmqctl list_user_permissions admin

然后使用 admin 管理员用户登录web管理页面

用户和密码是上面添加设置的 admin admin
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值