您好,登錄后才能下訂單哦!
這篇“node中怎么使用消息隊列”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“node中怎么使用消息隊列”文章吧。
什么是消息隊列
消息隊列就是消息的傳輸過程中保存消息的容器,本質是一個隊列(先進先出)
消息
指的是需要傳輸的數據,可以是一些文本,字符串,或者是對象等信息。
消息隊列
則是兩個應用間的通信服務,消息的產生者
將數據存放到消息隊列中就可以立即返回,不需要等待消息的接收者
應答。即:生產者
保證數據插入隊列,誰來取這條消息不需要管。消息的接收者
則只專注于接受消息并處理。
消息隊列能做什么
解耦 上面介紹了,消息隊列將消息的生產者和消息的接收者分開,彼此都不受影響。
異步 異步就是為了減少請求的響應時間,消息的生產者只需要處理簡單的邏輯,并將數據放到消息隊列中即可返回,復雜的邏輯,比如:數據庫操作,IO操作由消息的接收者處理。
削峰 消息隊列應用在服務時,能將瞬時大量涌入的請求信息保存到消息隊列中,并立即返回。再由消息的接收者根據數據處理請求。
應用場景 游戲活動,秒殺活動,下單等會造成瞬時流量暴增的應用。
介紹完消息隊列的基本信息,在開發消息隊列之前先介紹一下消息隊列的一些基本概念~
消息的生產者(producer)與消費者(customer)
上文提到的生產者
與消費者
,提供的是
鏈接,通道與隊列
鏈接(connection):表示服務程序與消息隊列之間的一條鏈接。一個服務程序可以創建多條鏈接。
通道(channel):消息隊列鏈接之間的一個通,一個鏈接可以有多個通道。
隊列(queue):消息隊列中存放數據的隊列,一個消息隊列服務可以有多個隊列。
總結一下,鏈接,通道隊列之間的關系是這樣的
交換機(exchange)
消息隊列發送消息時必須要有一個交換機,如果沒有指定則用的是默認的交換機。交換機的作用就是將消息才推到對應的隊列中。消息隊列中一共有4種交換機
Direct: 指定隊列模式,消息來了,只發給指定的Queue,其他Queue都收不到。
fanout: 廣播模式,消息來了,就會發送給所有的隊列。
topic: 模糊匹配模式,通過模糊匹配的方式進行相應轉發。
header: 與Direct模式類似。
安裝rabbitMQ
安裝rabbitMQ可以通過官網上進行下載安裝,傳送門
MAC可以直接用brew命令安裝
brew install rabbitmq
安裝完成后啟動rabbitmq服務
然后再本地中訪問 http://localhost:15672/ 就可以看到rabbitmq服務的后臺。初始的賬號密碼均為 guest
node項目安裝amqplib
amqplib是node中使用消息隊列的一套工具,可以讓我們快速地使用消息隊列
創建生產者
/** product.js 消費者 */ const amqplib = require('amqplib'); const config = require('./config'); const { connectUrl } = config; (async () => { const connection = await amqplib.connect(connectUrl); const channel = await connection.createChannel(); const exchangeName = 'testExchange'; const key = 'testQueue'; const sendMsg = 'hello rabbitmq'; // 知道交換機類型 await channel.assertExchange(exchangeName, 'fanout', { durable: true, }); // 指定一個隊列 await channel.assertQueue(key); for (let i = 0; i < 100; i++) { channel.publish(exchangeName, key, Buffer.from(`${sendMsg} ${i}`)); } await channel.close(); await connection.close(); })();
運行后在后臺可以看到新增了一個有100條消息的隊列
創建消費者
/** customer.js 消費者 */ const amqplib = require('amqplib'); const config = require('./config'); const { connectUrl } = config; (async () => { let connection = await amqplib.connect(connectUrl); const exchangeName = 'testExchange'; const key = 'testQueue'; // 創建兩個通道 const channel1 = await connection.createChannel(); const channel2 = await connection.createChannel(); // 指定一個交換機 await channel1.assertExchange(exchangeName, 'fanout', { durable: true, }); // 指定一個隊列 await channel1.assertQueue(key); await channel1.bindQueue(key, exchangeName, key); channel1.consume(key, (msg) => { console.log('channel 1', msg.content.toString()); }); await channel2.assertExchange(exchangeName, 'fanout', { durable: true, }); await channel2.assertQueue(key); await channel2.bindQueue(key, exchangeName, key); channel2.consume(key, (msg) => { console.log('channel 2', msg.content.toString()); }); })();
執行后可以看到,兩個通道可以同時工作接收消息
以上就是關于“node中怎么使用消息隊列”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。