node后端服務(wù)?;畹膶?shí)現(xiàn)
引言
目前的項(xiàng)目中使用了node,作為一個(gè)簡(jiǎn)單的后端服務(wù),隨著承擔(dān)著越來越多的線上業(yè)務(wù)的服務(wù),就要求了服務(wù)端的穩(wěn)定性,而其中最重要的一點(diǎn)就是服務(wù)?;?。有進(jìn)程終止后自動(dòng)重啟的能力。
forever
forever是一個(gè)簡(jiǎn)單的命令行工具,他能確保一個(gè)給定的腳本持續(xù)運(yùn)行。forever完全基于命令行操作,在forever進(jìn)程之下,創(chuàng)建node的子進(jìn)程,通過monitor監(jiān)控node子進(jìn)程的運(yùn)行情況,一旦文件更新,或者進(jìn)程掛掉,forever會(huì)自動(dòng)重啟node服務(wù)器,確保應(yīng)用正常運(yùn)行。
所以就看一下forever的項(xiàng)目吧。主要的進(jìn)程控制方面的代碼地址。
start方法
let child_process = require('child_process')
let spawn = child_process.spawn
Monitor.prototype.start = function (restart) {
var self = this,
child;
child = this.trySpawn();
...
return this;
};
Monitor.prototype.trySpawn = function () {
var run = this.parser(this.command, this.args.slice()),
stats;
return spawn(run.command, run.args, this.spawnWith);
};
核心就是使用了node api 中的 spawn,創(chuàng)建子進(jìn)程,這個(gè)子進(jìn)程就是我們真正的需要運(yùn)行的node端服務(wù)。
自動(dòng)restart
父子進(jìn)程的通信核心就是為了?;?,主要就是監(jiān)聽了子進(jìn)程,也就是需要被守護(hù)進(jìn)程的exit事件
child.on('exit', function (code, signal) {
var spinning = Date.now() - self.ctime < self.minUptime;
child.removeListener('message', onMessage);
self.emit('exit:code', code, signal);
function letChildDie() {
self.running = false;
self.forceStop = false;
self.emit('exit', self, spinning);
}
function restartChild() {
self.forceRestart = false;
process.nextTick(function () {
self.start(true);
});
}
self.times++;
if (self.forceStop || (self.times >= self.max && !self.forceRestart)
|| (spinning && typeof self.spinSleepTime !== 'number') && !self.forceRestart) {
letChildDie();
}
else if (spinning) {
setTimeout(restartChild, self.spinSleepTime);
}
else {
restartChild();
}
});
邏輯很簡(jiǎn)單,分別兩個(gè)場(chǎng)景,一個(gè)是希望子進(jìn)程不要再啟動(dòng),一般就是外部控制殺死的;一個(gè)是意外退出后的重啟,此處與一個(gè)spinning值的判斷,也就是在退出后存在一個(gè)重啟的時(shí)間間隔。
父子進(jìn)程通信
message事件來監(jiān)聽,用send方法來發(fā)送事件,父子進(jìn)程通信就可以用做外部的控制的實(shí)現(xiàn)了。這里我們還需要注意一個(gè)細(xì)節(jié),就是node后端服務(wù)運(yùn)行中會(huì)輸出很多的日志,此時(shí)放在子進(jìn)程中的控制臺(tái)輸出,如果希望暴露出來就可以使用options.stdio屬性。
總結(jié)
?;畹膱?chǎng)景很多,這里可以使用forever庫來處理,配合監(jiān)控和日志功能,更好的保證線上環(huán)境的穩(wěn)定。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
node.js中實(shí)現(xiàn)token的生成與驗(yàn)證的操作方法
Token是一種用于在客戶端和服務(wù)器之間安全傳輸信息的加密字符串,常用于身份驗(yàn)證、授權(quán)、狀態(tài)管理和安全性,在Node.js中,常用jsonwebtoken庫生成和驗(yàn)證Token,本文介紹node.js中實(shí)現(xiàn)token的生成與驗(yàn)證的操作方法,感興趣的朋友一起看看吧2025-01-01
nodejs利用readline提示輸入內(nèi)容實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于nodejs利用readline提示輸入內(nèi)容的相關(guān)資料,Readline是Node.js里實(shí)現(xiàn)標(biāo)準(zhǔn)輸入輸出的封裝好的模塊,通過這個(gè)模塊我們可以以逐行的方式讀取數(shù)據(jù)流,需要的朋友可以參考下2021-07-07
node.js實(shí)現(xiàn)http服務(wù)器與瀏覽器之間的內(nèi)容緩存操作示例
這篇文章主要介紹了node.js實(shí)現(xiàn)http服務(wù)器與瀏覽器之間的內(nèi)容緩存操作,結(jié)合實(shí)例形式分析了node.js http服務(wù)器與瀏覽器之間的內(nèi)容緩存原理與具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-02-02
Node.js原理阻塞和EventEmitter及其繼承的運(yùn)用實(shí)戰(zhàn)
這篇文章主要介紹了Node.js原理阻塞和EventEmitter及其繼承的運(yùn)用實(shí)戰(zhàn),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08
npm?install?XXX安裝路徑文件夾權(quán)限問題的解決過程
這篇文章主要給大家介紹了關(guān)于npm?install?XXX安裝路徑文件夾權(quán)限問題(npm?ERR!?The?operation?was?rejected?by?your?operating?system.errno?-4080)的解決過程,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04

