亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    一文淺析node中如何使用消息隊(duì)列

    什么是消息隊(duì)列?下面本篇文章帶大家了解一下消息隊(duì)列的基本概念,介紹一下node中如何使用消息隊(duì)列,希望對大家有所幫助!

    一文淺析node中如何使用消息隊(duì)列

    1.消息隊(duì)列

    什么是消息隊(duì)列

    消息隊(duì)列就是消息的傳輸過程中保存消息的容器,本質(zhì)是一個(gè)隊(duì)列(先進(jìn)先出)

    一文淺析node中如何使用消息隊(duì)列

    消息指的是需要傳輸?shù)臄?shù)據(jù),可以是一些文本,字符串,或者是對象等信息。

    消息隊(duì)列則是兩個(gè)應(yīng)用間的通信服務(wù),消息的產(chǎn)生者將數(shù)據(jù)存放到消息隊(duì)列中就可以立即返回,不需要等待消息的接收者應(yīng)答。即:生產(chǎn)者保證數(shù)據(jù)插入隊(duì)列,誰來取這條消息不需要管。消息的接收者則只專注于接受消息并處理?!鞠嚓P(guān)教程推薦:nodejs視頻教程、編程教學(xué)】

    一文淺析node中如何使用消息隊(duì)列

    消息隊(duì)列能做什么

    • 解耦 上面介紹了,消息隊(duì)列將消息的生產(chǎn)者和消息的接收者分開,彼此都不受影響。

    • 異步 異步就是為了減少請求的響應(yīng)時(shí)間,消息的生產(chǎn)者只需要處理簡單的邏輯,并將數(shù)據(jù)放到消息隊(duì)列中即可返回,復(fù)雜的邏輯,比如:數(shù)據(jù)庫操作,IO操作由消息的接收者處理。

    • 削峰 消息隊(duì)列應(yīng)用在服務(wù)時(shí),能將瞬時(shí)大量涌入的請求信息保存到消息隊(duì)列中,并立即返回。再由消息的接收者根據(jù)數(shù)據(jù)處理請求。

    • 應(yīng)用場景 游戲活動(dòng),秒殺活動(dòng),下單等會(huì)造成瞬時(shí)流量暴增的應(yīng)用。

    2.消息隊(duì)列的概念

    介紹完消息隊(duì)列的基本信息,在開發(fā)消息隊(duì)列之前先介紹一下消息隊(duì)列的一些基本概念~

    消息的生產(chǎn)者(producer)與消費(fèi)者(customer)

    上文提到的生產(chǎn)者消費(fèi)者,提供的是

    鏈接,通道與隊(duì)列

    • 鏈接(connection):表示服務(wù)程序與消息隊(duì)列之間的一條鏈接。一個(gè)服務(wù)程序可以創(chuàng)建多條鏈接。

    • 通道(channel):消息隊(duì)列鏈接之間的一個(gè)通,一個(gè)鏈接可以有多個(gè)通道。

    • 隊(duì)列(queue):消息隊(duì)列中存放數(shù)據(jù)的隊(duì)列,一個(gè)消息隊(duì)列服務(wù)可以有多個(gè)隊(duì)列。

    總結(jié)一下,鏈接,通道隊(duì)列之間的關(guān)系是這樣的

    一文淺析node中如何使用消息隊(duì)列

    交換機(jī)(exchange)

    消息隊(duì)列發(fā)送消息時(shí)必須要有一個(gè)交換機(jī),如果沒有指定則用的是默認(rèn)的交換機(jī)。交換機(jī)的作用就是將消息才推到對應(yīng)的隊(duì)列中。消息隊(duì)列中一共有4種交換機(jī)

    • Direct: 指定隊(duì)列模式,消息來了,只發(fā)給指定的Queue,其他Queue都收不到。

    • fanout: 廣播模式,消息來了,就會(huì)發(fā)送給所有的隊(duì)列。

    • topic: 模糊匹配模式,通過模糊匹配的方式進(jìn)行相應(yīng)轉(zhuǎn)發(fā)。

    • header: 與Direct模式類似。

    3.node使用rabbitMQ

    安裝rabbitMQ

    • 安裝rabbitMQ可以通過官網(wǎng)上進(jìn)行下載安裝,傳送門
    • MAC可以直接用brew命令安裝
      brew install rabbitmq
      登錄后復(fù)制

    • 安裝完成后啟動(dòng)rabbitmq服務(wù)

    一文淺析node中如何使用消息隊(duì)列

    然后再本地中訪問 http://localhost:15672/ 就可以看到rabbitmq服務(wù)的后臺(tái)。初始的賬號密碼均為 guest

    一文淺析node中如何使用消息隊(duì)列

    node項(xiàng)目安裝amqplib

    amqplib是node中使用消息隊(duì)列的一套工具,可以讓我們快速地使用消息隊(duì)列

    地址:https://www.npmjs.com/package/amqplib

    創(chuàng)建生產(chǎn)者

    /** product.js 消費(fèi)者 */   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';        // 知道交換機(jī)類型   await channel.assertExchange(exchangeName, 'fanout', {     durable: true,   });        // 指定一個(gè)隊(duì)列   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(); })();
    登錄后復(fù)制

    運(yùn)行后在后臺(tái)可以看到新增了一個(gè)有100條消息的隊(duì)列

    一文淺析node中如何使用消息隊(duì)列

    創(chuàng)建消費(fèi)者

    /** customer.js 消費(fèi)者 */  const amqplib = require('amqplib'); const config = require('./config');  const { connectUrl } = config;  (async () => {   let connection = await amqplib.connect(connectUrl);   const exchangeName = 'testExchange';   const key = 'testQueue';   // 創(chuàng)建兩個(gè)通道   const channel1 = await connection.createChannel();   const channel2 = await connection.createChannel();   // 指定一個(gè)交換機(jī)   await channel1.assertExchange(exchangeName, 'fanout', {     durable: true,   });   // 指定一個(gè)隊(duì)列   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());   }); })();
    登錄后復(fù)制

    執(zhí)行后可以看到,兩個(gè)通道可以同時(shí)工作接收消息

    一文淺析node中如何使用消息隊(duì)列

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號