詳解Node.js amqplib 連接 Rabbit MQ最佳實踐
客戶端設(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)
一個進程,一個channel, 一個connection,如果一個pod向RabbitMQ建立了多條tcp連接,你就要警惕了。
監(jiā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í)有所幫助,也希望大家多多支持腳本之家。
- node.js學(xué)習(xí)筆記之koa框架和簡單爬蟲練習(xí)
- 手把手教你用Node.js爬蟲爬取網(wǎng)站數(shù)據(jù)的方法
- 利用node.js寫一個爬取知乎妹紙圖的小爬蟲
- 從零搭建docker+jenkins+node.js自動化部署環(huán)境的方法
- Docker使用編寫dockerfile啟動node.js應(yīng)用
- Node.js Buffer模塊功能及常用方法實例分析
- Node.js net模塊功能及事件監(jiān)聽用法分析
- Docker部署Node.js的方法步驟
- 一步步教你利用Docker設(shè)置Node.js
- 基于node.js實現(xiàn)爬蟲的講解
相關(guān)文章
從零學(xué)習(xí)node.js之模塊規(guī)范(一)
Node.js是一個基于谷歌瀏覽器JavaScript執(zhí)行環(huán)境建立的一個平臺,讓JavaScript可以脫離客戶端瀏覽器運行,讓 JavaScript具有服務(wù)器語言的能力。從本文開始我們進行學(xué)習(xí)node.js,這篇文章主要介紹的是node.js中模塊規(guī)范的相關(guān)資料,需要的朋友可以參考下。2017-02-02
詳解基于 Node.js 的輕量級云函數(shù)功能實現(xiàn)
這篇文章主要介紹了詳解基于 Node.js 的輕量級云函數(shù)功能實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
輕松創(chuàng)建nodejs服務(wù)器(3):代碼模塊化
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(3):代碼模塊化,本文是對第一節(jié)的例子作了封裝,需要的朋友可以參考下2014-12-12
node.js 開發(fā)指南 – Node.js 連接 MySQL 并進行數(shù)據(jù)庫操作
通常在NodeJS開發(fā)中我們經(jīng)常涉及到操作數(shù)據(jù)庫,尤其是 MySQL ,作為應(yīng)用最為廣泛的開源數(shù)據(jù)庫則成為我們的首選,本篇就來介紹下如何通過NodeJS來操作 MySQL 數(shù)據(jù)庫。2014-07-07

