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