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更高 文章来源:https://www.toymoban.com/news/detail-689284.html
4.Rabbitmq安装
1 centos 安装
# 安装配置epel源
# 安装erlang
yum -y install erlang
# 安装RabbitMQ
yum -y install rabbitmq-server
2.windows安装
-官网下载erlang,版本跟rabbimq版本有对应关系
-rabbimq 官网下载安装包:https://github.com/rabbitmq/rabbitmq-server/releases
3 docker运行
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连接时候,指定这个端口文章来源地址https://www.toymoban.com/news/detail-689284.html
到了这里,关于消息队列-------Rabbitmq介绍和安装的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!