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