Nodejs 第七十五章(MQ)

2,755 阅读3分钟

什么是RabbitMQ?

  • RabbitMQ是一个开源的,在AMQP基础上完整的,可复用的企业消息系统。
  • 支持主流的操作系统,Linux、Windows、MacOS等
  • 多种开发语言支持,Java、Python、Ruby、.NET、PHP、C/C++、javaScript等

AMQP(高级消息队列协议) 实现了对于消息的排序,点对点通讯,和发布订阅,保持可靠性、保证安全性。

RabbitMQ核心概念

  1. 消息:在RabbitMQ中,消息是传递的基本单元。它由消息体和可选的属性组成
  2. 生产者Producer:生产者是消息的发送方,它将消息发送到RabbitMQ的交换器(Exchange)中
  3. 交换器Exchange:交换器接收从生产者发送的消息,并根据特定的规则将消息路由到一个或多个队列中
  4. 队列Queue:队列是消息的接收方,它存储了待处理的消息。消费者可以从队列中获取消息并进行处理
  5. 消费者Consumer:消费者是消息的接收方,它从队列中获取消息并进行处理

image.png

RabbitMQ 的安装

1. Rabbit MQ的依赖环境erlang

因为MQ是基于这个语言开发的

官网下载erlang:www.erlang.org/downloads

image.png

安装完成之后 新增一个环境变量

image.png

ERLANG_HOME -> 对应的目录例如(D:\erlang\Erlang OTP)

然后path 新增 %ERLANG_HOME%\bin

image.png

保存 打开cdm 输入 erl 没有报错即可成功

image.png
2. 安装MQ

打开MQ官网

image.png

例如windows

image.png

安装完成之后配置环境变量

image.png
启动MQ

安装MQ插件拥有可视化面板

rabbitmq-plugins enable rabbitmq_management
image.png

启动MQ命令

MQ默认端口5672

rabbitmq-server.bat start
image.png

访问 http://localhost:15672/#/ 账号密码都是 guest

image.png

Nodejs使用

我们在Nodejs使用MQ 无非就是微服务应用,或者就是跨语言通讯

安装依赖

npm install amqplib

producer.js 生产者

import express from 'express'
import amqplib from "amqplib";

const app = express()
//连接MQ
const connection = await amqplib.connect("amqp://localhost")
//创建一个通道
const channel = await connection.createChannel()
const queueName = "task_queue"
app.get('/send', (req, res) => {
    const message = req.query.message
    //发送消息
    channel.sendToQueue(queueName, Buffer.from(message),{
        persistent: true //持久化消息
    })
    res.send('send message success')
})


app.listen(3000,()=>{
    console.log('producer listen 3000')
})

consume.js 消费者

import amqplib from "amqplib";
const queueName = "task_queue"
//连接
const connection = await amqplib.connect("amqp://localhost")
const channel = await connection.createChannel()

//连接队列
await channel.assertQueue(queueName, {
  durable: true //队列持久化
})
//消息者监听器
channel.consume(queueName, (msg) => {
  console.log(`[x] Received ${msg.content.toString()}`)
  channel.ack(msg) //确认消费该消息
})

持久化实现

生产者把消息推入队列此时宕机了,重启之后消息丢失,为了解决这个问题我们需要实现持久化策略

  1. 队列持久化 消费者连接队列的时候开启 durable: true 即可实现队列持久化
  2. 消息持久化 发送方 在发送消息的时候 开启 persistent: true 即可持久化

甚至还可以跨语言通讯 python

import pika

connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))

channel = connection.channel()

queueName = 'task_queue'

channel.queue_declare(queue=queueName,durable=True)

message = '小满zs'

channel.basic_publish(exchange='',routing_key=queueName,body=message)

connection.close()

应用场景

  1. 微服务之间的通讯,或者跨语言级别通讯
  2. 异步任务,比如执行完成一个接口需要发送邮件,我们无需等待邮件发送完成再返回,我们可以直接返回结果,在异步任务中处理邮件。
  3. 日志的收集和分发,将应用程序的日志消息发送到 RabbitMQ 队列中,然后使用消费者进行处理和分发。这样可以集中管理和处理日志,提供实时监控和分析

效果展示

1.gif