RabbitMQ简介

RabbitMQ简介

1、RabbitMQ简介

1.1、简介

RabbitMQ是一个广泛使用的消息服务器,采用Erlang语言编写,是一种开源的实现 AMQP(高级消息队列协议)的消息中间件;

RabbitMQ最初起源于金融系统,它的性能及稳定性都非常出色;

AMQP协议(http://www.amqp.org),即 Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计;

我们学的协议有哪些:(http、ftp)

1.2、相关网址

RabbitMQ官网:https://www.rabbitmq.com

Github:https://github.com/rabbitmq

1.3、消息中间件(MQ=Message Queue)

简单来说,消息中间件就是指保存数据的一个容器(服务器),可以用于两个系统之间的数据传递。

消息中间件一般有三个主要角色:生产者、消费者、消息代理(消息队列、消息服务器);

生产者发送消息到消息服务器,然后消费者从消息代理(消息队列)中获取数据并进行处理;

1.4、常用的消息中间件

目前比较主流的几个消息中间件:

  • RabbitMQ
  • kafka(大数据领域)
  • RocketMQ(阿里巴巴开源)献给Apache组织
  • pulsar(最近一两年流行起来的)

2、MQ(Message Queue)的应用场景

2.1、异步处理

下订单:下订单--》加积分--》发红包--》发手机短信

下订单---向MQ 发消息--》积分系统,红包系统,手机短信系统接收消息

同步是阻塞的(会造成等待),异步是非阻塞的(不会等待);

大流量高并发请求、批量数据传递,就可以采用异步处理,提升系统吞吐量;

2.2、系统解耦

多个系统之间,不需要直接交互,通过消息进行业务流转;

2.3、流量削峰

高负载请求/任务的缓冲处理;

2.4、日志处理

主要是用kafka这个服务器来做;

日志处理是指将消息队列用于在日志处理中,比如Kafka解决大量日志传输的问题;

loger.info(...)

ELK 日志处理解决方案:

loger.error(...) -->logstash收集消息--> 发送消息的kafka --> elastic search (es) -->Kibana ELK日志处理平台

相关推荐
群联云防护小杜1 小时前
云服务器主动防御策略与自动化防护(下)
运维·服务器·分布式·安全·自动化·音视频
TE-茶叶蛋3 小时前
秒杀压测计划 + Kafka 分区设计参考
分布式·kafka
青铜爱码士6 小时前
redis+lua+固定窗口实现分布式限流
redis·分布式·lua
啊喜拔牙8 小时前
如何搭建spark yarn模式的集群
大数据·分布式·spark
听雨·眠8 小时前
关于kafka
分布式·kafka·消息队列
TE-茶叶蛋8 小时前
NestJS + Kafka 秒杀系统完整实践总结
分布式·kafka
慧一居士9 小时前
Kafka批量消费部分处理成功时的手动提交方案
分布式·后端·kafka
搞不懂语言的程序员10 小时前
如何实现Kafka的Exactly-Once语义?
分布式·kafka·linq
ErizJ10 小时前
Golang|分布式索引架构
开发语言·分布式·后端·架构·golang
zcyf080911 小时前
kafka理论学习汇总
java·分布式·学习·kafka