使用upstart把nodejs應(yīng)用封裝為系統(tǒng)服務(wù)實(shí)例
一、nodejs應(yīng)用普通部署方式介紹
終于要把nodejs的應(yīng)用程序部署上線了, 把源代碼通過(guò)git復(fù)制到目錄下面
然后搞命令:
~ cd /root/deploy/movie
node ./app.js
上面的方式,nodejs程序會(huì)在當(dāng)前的console界面中運(yùn)行,一旦console結(jié)束,應(yīng)用也會(huì)停止。我們改一下命令,讓程序在后臺(tái)運(yùn)行
~ 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)程,再殺死。
~ 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ù)腳本
~ 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
~ 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)行
~ status nodejs-moive
nodejs-moive start/running, process 21257
殺死nodejs應(yīng)用進(jìn)程21257,通過(guò)upstart管理,nodejs-moive應(yīng)用會(huì)自動(dòng)重啟
~ 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>
- nodejs入門(mén)教程一:概念與用法簡(jiǎn)介
- NodeJS測(cè)試框架mocha入門(mén)教程
- Nodejs極簡(jiǎn)入門(mén)教程(三):進(jìn)程
- Nodejs極簡(jiǎn)入門(mén)教程(二):定時(shí)器
- Nodejs極簡(jiǎn)入門(mén)教程(一):模塊機(jī)制
- nodejs使用express創(chuàng)建一個(gè)簡(jiǎn)單web應(yīng)用
- Docker實(shí)踐--部署Nodejs應(yīng)用
- NodeJS創(chuàng)建基礎(chǔ)應(yīng)用并應(yīng)用模板引擎
- NodeJS Web應(yīng)用監(jiān)聽(tīng)sock文件實(shí)例
- Nginx做NodeJS應(yīng)用負(fù)載均衡配置實(shí)例
- NodeJS學(xué)習(xí)筆記之Connect中間件應(yīng)用實(shí)例
- 使用forever管理nodejs應(yīng)用教程
- nodejs入門(mén)教程二:創(chuàng)建一個(gè)簡(jiǎn)單應(yīng)用示例
相關(guān)文章
Node.js的路由、EJS模板引擎、GET和POST請(qǐng)求講解
這篇文章介紹了Node.js的路由、EJS模板引擎、GET和POST請(qǐng)求,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06npm報(bào)錯(cuò):npm?WARN?config?global?'--global',?&apo
這篇文章主要給大家介紹了關(guān)于npm報(bào)錯(cuò):npm?WARN?config?global?'--global',?'--local'?are?deprecated.?Use?`--location=global`?instead.的解決方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08輕松創(chuàng)建nodejs服務(wù)器(4):路由
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(4):路由,服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來(lái)執(zhí)行不一樣的操作,我們可以通過(guò)路由來(lái)實(shí)現(xiàn)這個(gè)步驟,需要的朋友可以參考下2014-12-12Node.js文件系統(tǒng)fs擴(kuò)展fs-extra說(shuō)明
這篇文章主要介紹了Node.js文件系統(tǒng)fs擴(kuò)展fs-extra說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08從零開(kāi)始學(xué)習(xí)Node.js系列教程四:多頁(yè)面實(shí)現(xiàn)數(shù)學(xué)運(yùn)算的client端和server端示例
這篇文章主要介紹了Node.js多頁(yè)面實(shí)現(xiàn)數(shù)學(xué)運(yùn)算的client端和server端,結(jié)合具體實(shí)例形式分析了nodejs客戶端提交與服務(wù)端處理實(shí)現(xiàn)數(shù)學(xué)運(yùn)算的相關(guān)操作技巧,需要的朋友可以參考下2017-04-04nodejs實(shí)例解析(輸出hello world)
本文主要介紹nodejs實(shí)例解析:輸出hello world的完整過(guò)程。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01Ajax獲取node服務(wù)器數(shù)據(jù)的完整步驟
這篇文章主要給大家介紹了關(guān)于Ajax獲取node服務(wù)器數(shù)據(jù)的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09iPhone手機(jī)上搭建nodejs服務(wù)器步驟方法
這篇文章主要介紹了iPhone手機(jī)上搭建nodejs服務(wù)器步驟方法,本文給出了詳細(xì)的操作步驟以及操作命令,需要的朋友可以參考下2015-07-07