溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

詳解Node.js amqplib 連接 Rabbit MQ最佳實踐

發(fā)布時間:2020-10-10 14:28:43 來源:腳本之家 閱讀:841 作者:wangduanduan 欄目:web開發(fā)

客戶端設(shè)置connection_name

在建立連接時,設(shè)置connection_name屬性,可以在RabbitMQ Managerment 中查看到連接來自那個實例。

amqp.connect(rabbitMqAddress, {
  clientProperties: {
   connection_name: 'your host name'
  }
})

隊列屬性autoDelete durable

如無必要,建議將隊列設(shè)置成自動刪除,這個在TCP連接斷開后,隊列會自動刪除。另外也不要使用持久化隊列。

channel.assertQueue(queueName, {
  autoDelete: true,
  durable: false
})

connnection 和 channel管理

connnection的內(nèi)存消耗。一個connection至少要使用100kb的內(nèi)存空間,過多的connetion占用將會導(dǎo)致內(nèi)存溢出,服務(wù)崩潰等問題。(我曾遇到過生產(chǎn)系統(tǒng),RabbitMQ連接過多,系統(tǒng)一直處于崩潰邊緣的險境)

重用connection或者channel,而不要重復(fù)開關(guān),下面給出AMQP各個階段所耗費的tcp包,重復(fù)的開關(guān),將會導(dǎo)致

  • AMQP connections: 7 TCP packages
  • AMQP channel: 2 TCP packages
  • AMQP publish: 1 TCP package (more for larger messages)
  • AMQP close channel: 2 TCP packages
  • AMQP close connection: 2 TCP packages
Total 14-19 packages (+ Acks)

一個進(jìn)程,一個channel, 一個connection,如果一個pod向RabbitMQ建立了多條tcp連接,你就要警惕了。

監(jiān)控進(jìn)程與RabbitMQ TCP連接數(shù),將NodeJS的運行信息寫入influxDB,并在grafana做監(jiān)控和告警。其中tcp連接數(shù)可以使用shelljs執(zhí)行命令獲取。

function getRabbitMqConnnectionCount (params) {
 shell.exec(`netstat -nt | grep ${rabbitmqHost} | wc -l`, (code, stdout, stderr) => {
  try {
   if (code === 0) {
    rabbitMqConnnectionCount = parseInt(stdout) || 0
   }
  } catch (error) {
   log.error(error.message)
  }
 })
}

參考

https://www.cloudamqp.com/blog/2017-12-29-part1-rabbitmq-best-practice.html
https://www.cloudamqp.com/blog/2018-01-08-part2-rabbitmq-best-practice-for-high-performance.html
https://www.cloudamqp.com/blog/2018-01-19-part4-rabbitmq-13-common-errors.html

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI