溫馨提示×

溫馨提示×

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

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

node后端服務(wù)?;畹膶?shí)現(xiàn)

發(fā)布時(shí)間:2020-10-20 07:19:59 來源:腳本之家 閱讀:230 作者:求實(shí)亭下 欄目:web開發(fā)

引言

目前的項(xiàng)目中使用了node,作為一個(gè)簡單的后端服務(wù),隨著承擔(dān)著越來越多的線上業(yè)務(wù)的服務(wù),就要求了服務(wù)端的穩(wěn)定性,而其中最重要的一點(diǎn)就是服務(wù)?;?。有進(jìn)程終止后自動(dòng)重啟的能力。

forever

forever是一個(gè)簡單的命令行工具,他能確保一個(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();
  }
 });

邏輯很簡單,分別兩個(gè)場景,一個(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é)

?;畹膱鼍昂芏啵@里可以使用forever庫來處理,配合監(jiān)控和日志功能,更好的保證線上環(huán)境的穩(wěn)定。

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

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