消息队列-------Rabbitmq介绍和安装

1.消息队列介绍

消息队列就是基础数据结构中的"先进先出"的一种数据机构。想一下,生活中买东西,需要排队,先排的人先买消费,就是典型的"先进先出"

2.消息队列MQ可以解决的问题

MQ是一直存在,不过随着微服务架构的流行,成了解决微服务之间问题的常用工具。

1.应用解耦

单体应用---》分布式应用

-把一个大功能拆分成小功能,功能直接数据使用mq交互

以电商应用为例,应用中有订单系统、库存系统、物流系统、支付系统。用户创建订单后,如果耦合调用库存系统、物流系统、支付系统,任何一个子系统出了故障,都会造成下单操作异常。

当转变成基于消息队列的方式后,系统间调用的问题会减少很多,比如物流系统因为发生故障,需要几分钟来修复。在这几分钟的时间里,物流系统要处理的内存被缓存在消息队列中,用户的下单操作可以正常完成。当物流系统恢复后,继续处理订单信息即可,中单用户感受不到物流系统的故障。提升系统的可用性

2.流量消峰 ------------秒杀场景,

举个栗子,如果订单系统最多能处理一万次订单,这个处理能力应付正常时段的下单时绰绰有余,正常时段我们下单一秒后就能返回结果。但是在高峰期,如果有两万次下单操作系统是处理不了的,只能限制订单超过一万后不允许用户下单。

使用消息队列做缓冲,我们可以取消这个限制,把一秒内下的订单分散成一段时间来处理,这事有些用户可能在下单十几秒后才能收到下单成功的操作,但是比不能下单的体验要好。

3.消息分发-------发布订阅

多个服务队数据感兴趣,只需要监听同一类消息即可处理。

例如A产生数据,B对数据感兴趣。如果没有消息的队列A每次处理完需要调用一下B服务。过了一段时间C对数据也感性,A就需要改代码,调用B服务,调用C服务。只要有服务需要,A服务都要改动代码。很不方便。

有了消息队列后,A只管发送一次消息,B对消息感兴趣,只需要监听消息。C感兴趣,C也去监听消息。A服务作为基础服务完全不需要有改动

4.异步消息

如果使用resful调用---》同步调用

-发送了调用请求后,继续干自己的活,等另一个服务数据准备好,会放到mq中,再去mq中取

3常见消息队列比较

rabbitmq和kafka

-编程语言不通erlang,java

-对客户端支持都一样

-处理数据能力:rabbitmq低于kafak

-可靠性:rabbitmq更高

4.Rabbitmq安装

1 centos 安装

python 复制代码
# 安装配置epel源
# 安装erlang
yum -y install erlang
# 安装RabbitMQ
yum -y install rabbitmq-server

2.windows安装

python 复制代码
-官网下载erlang,版本跟rabbimq版本有对应关系
-rabbimq 官网下载安装包:https://github.com/rabbitmq/rabbitmq-server/releases

3 docker运行

python 复制代码
docker pull rabbitmq:management
# 设置用户名和密码,做端口映射:一个端口是web界面的端口,另一个端口是服务端口
docker run -di --name Myrabbitmq -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -p 15672:15672 -p 5672:5672 rabbitmq:management

web 管理页面的端口是 15672

服务端口是5672,使用python连接时候,指定这个端口

相关推荐
TE-茶叶蛋2 分钟前
秒杀压测计划 + Kafka 分区设计参考
分布式·kafka
青铜爱码士4 小时前
redis+lua+固定窗口实现分布式限流
redis·分布式·lua
啊喜拔牙5 小时前
如何搭建spark yarn模式的集群
大数据·分布式·spark
听雨·眠6 小时前
关于kafka
分布式·kafka·消息队列
TE-茶叶蛋6 小时前
NestJS + Kafka 秒杀系统完整实践总结
分布式·kafka
慧一居士7 小时前
Kafka批量消费部分处理成功时的手动提交方案
分布式·后端·kafka
搞不懂语言的程序员7 小时前
如何实现Kafka的Exactly-Once语义?
分布式·kafka·linq
ErizJ7 小时前
Golang|分布式索引架构
开发语言·分布式·后端·架构·golang
zcyf08098 小时前
kafka理论学习汇总
java·分布式·学习·kafka
xiaoxi6669 小时前
Dubbo实战:四步实现注册中心平滑迁移
分布式·nacos·dubbo·注册中心