欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用upstart把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)實(shí)例

 更新時(shí)間:2014年06月01日 21:59:21   作者:  
這篇文章主要介紹了使用upstart把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)實(shí)例,需要的朋友可以參考下

一、nodejs應(yīng)用普通部署方式介紹

終于要把nodejs的應(yīng)用程序部署上線了, 把源代碼通過(guò)git復(fù)制到目錄下面

復(fù)制代碼 代碼如下:
/root/deploy/movie

然后搞命令:
復(fù)制代碼 代碼如下:

~ cd /root/deploy/movie
node ./app.js

上面的方式,nodejs程序會(huì)在當(dāng)前的console界面中運(yùn)行,一旦console結(jié)束,應(yīng)用也會(huì)停止。我們改一下命令,讓程序在后臺(tái)運(yùn)行

復(fù)制代碼 代碼如下:

~ node ./app.js &
[1] 21333
[2013-06-21 09:38:30.696] [INFO] console - Start App: http://jb51.net
[2013-06-21 09:38:30.700] [INFO] console - Express server listening on port 3000

這樣程序就就在后臺(tái)啟動(dòng)了。進(jìn)程正常運(yùn)行著,我也不用做太多的事情。

如果我想停止這個(gè)程序,怎么辦呢? 找到nodejs的系統(tǒng)進(jìn)程,再殺死。

復(fù)制代碼 代碼如下:

~ ps -aux|grep node
root     21333  0.6  3.7 909200 38292 pts/0    Sl   09:38   0:00 node app.js
~ kill -9 21333 

直接暴力解決。如果能像系統(tǒng)服務(wù)一樣,來(lái)啟動(dòng)和關(guān)閉nodejs應(yīng)用,多好??!下面就通過(guò)upstart來(lái)完成把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)。

二、 把應(yīng)用封裝為upstart任務(wù)腳本

復(fù)制代碼 代碼如下:

~ vi /etc/init/nodejs-moive.conf

description "node.js jb51.net"

start on startup
stop on shutdown

script
    export HOME="/root/deploy/movie"
    echo $$ > /var/run/moiveme.pid
    export NODE_ENV=production
    exec /usr/bin/node /root/deploy/movie/server.js

    #日志輸出
    #exec /usr/bin/node /root/deploy/movie/server.js >> /var/log/moiveme.log 2>&1
end script

pre-start script
    echo "[`date -u +%Y-%m-%dT%T.%3NZ`] (sys) Starting" >> /var/log/moiveme.log
end script

pre-stop script
    rm /var/run/moiveme.pid
    echo "[`date -u +%Y-%m-%dT%T.%3NZ`] (sys) Stopping" >> /var/log/moiveme.log
end script

三、 使用upstart管理nodejs應(yīng)用

啟動(dòng)nodejs-moive應(yīng)用(上面的任務(wù)腳本),進(jìn)程ID:21257

復(fù)制代碼 代碼如下:

~ start nodejs-moive
nodejs-moive start/running, process 21257

~ tail -f /var/log/moiveme.log
[2013-06-21T09:21:17.122Z] (moive.me) Starting

~ ps aux|grep node
root     21257  8.0  3.7 909204 37824 ?        Ssl  09:21   0:00 /usr/bin/node /root/deploy/movie/server.js


查看運(yùn)行狀態(tài), 進(jìn)程21257正常運(yùn)行
復(fù)制代碼 代碼如下:

~ status nodejs-moive
nodejs-moive start/running, process 21257

殺死nodejs應(yīng)用進(jìn)程21257,通過(guò)upstart管理,nodejs-moive應(yīng)用會(huì)自動(dòng)重啟

復(fù)制代碼 代碼如下:

~ kill -9 21257

#自動(dòng)重啟日志
~ tail -f /var/log/moiveme.log
[2013-06-21T09:21:33.662Z] (moive.me) Starting

#查看系統(tǒng)進(jìn)程,發(fā)現(xiàn)進(jìn)行ID變了
~ ps -aux|grep node
root     21280  9.1  3.7 909204 37704 ?        Ssl  09:21   0:00 /usr/bin/node /root/deploy/movie/server.js

#查看進(jìn)程狀態(tài),進(jìn)程ID確實(shí)變了,而且是自動(dòng)完成的
~ status nodejs-moive
nodejs-moive start/running, process 21280


這樣很方便地我們可以通過(guò)upstart,以系統(tǒng)服務(wù)的方式管理nodejs應(yīng)用。運(yùn)維起來(lái)會(huì)很容易?。?/P>

相關(guān)文章

最新評(píng)論