消息队列
消息队列是一种应用程序间通信技术,有助于构建通用集成机制,以支持云原生、基于微服务、无服务器和混合云架构。
kafka
Kafka和Mysql相比,都是需要
- 先下载安装对应的包
- 接着可以直接命令行调用
- 也可以通过 python、java 这样的编程语言来调用
- 都存在地址接口的概念,localhost:9092 指的是本机地址的 9092 端口
- 如果你想调用 Docker 里的端口,要提前通过--expose 暴露出这个端口
- 如果你想调用服务器的 kafka 或者 mysql,得填服务器的 ip+端口
Kafka 的应用场景
-
异步处理
- 可以将一些比较耗时的操作放在其他系统中,通过消息队列将需要进行处理的消息进行存储,其他系统可以消费消息队列中的数据
- 比较常见的:发送短信验证码、发送邮件
-
系统解耦
- 原先一个微服务是通过接口(HTTP)调用另一个微服务,这时候耦合很严重,只要接口发生变化就会导致系统不可用
- 使用消息队列可以将系统进行解耦合,现在第一个微服务可以将消息放入到消息队列中,另一个微服务可以从消息队列中把消息取出来进行处理。进行系统解耦
-
流量削峰
- 因为消息队列是低延迟、高可靠、高吞吐的,可以应对大量并发
-
日志处理
- 可以使用消息队列作为临时存储,或者一种通信管道
Kafka 消息队列的两种模型
- 生产者、消费者模型
- 生产者负责将消息生产到 MQ 中
- 消费者负责从 MQ 中获取消息
- 生产者和消费者是解耦的,可能是生产者一个程序、消费者是另外一个程序
- 消息队列的模式
- 点对点:一个消费者消费一个消息
- 发布订阅:多个消费者可以消费一个消息