这篇文章主要介绍了使用upstart把nodejs应用封装为系统服务实例,需要的朋友可以参考下

一、nodejs应用普通部署方式介绍

终于要把nodejs的应用程序部署上线了, 把源代码通过git复制到目录下面

/root/deploy/movie

然后搞命令:

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

上面的方式,nodejs程序会在当前的console界面中运行,一旦console结束,应用也会停止。我们改一下命令,让程序在后台运行


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

这样程序就就在后台启动了。进程正常运行着,我也不用做太多的事情。

如果我想停止这个程序,怎么办呢? 找到nodejs的系统进程,再杀死。


~ 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 

直接暴力解决。如果能像系统服务一样,来启动和关闭nodejs应用,多好啊!下面就通过upstart来完成把nodejs应用封装为系统服务。

二、 把应用封装为upstart任务脚本


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

description "node.js lovean.com"

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应用

启动nodejs-moive应用(上面的任务脚本),进程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


查看运行状态, 进程21257正常运行

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

杀死nodejs应用进程21257,通过upstart管理,nodejs-moive应用会自动重启


~ kill -9 21257

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

#查看系统进程,发现进行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

#查看进程状态,进程ID确实变了,而且是自动完成的
~ status nodejs-moive
nodejs-moive start/running, process 21280


这样很方便地我们可以通过upstart,以系统服务的方式管理nodejs应用。运维起来会很容易!!

最新资讯
淘宝回应口罩价格不稳等问题:相关商品下架 协助退款

淘宝回应口罩价格不稳

针对网友曝光有淘宝店铺口罩出现不实宣传、价格不稳等
华为中兴助力四川完成首例冠状病毒5G远程会诊

华为中兴助力四川完成

新型冠状病毒疫情攻坚已经进入了最关键的时刻。而克日
蝙蝠不招惹人类已是万幸,为什么还有人敢吃它们?

蝙蝠不招惹人类已是万

虽然之前被流传的一些蝙蝠汤之类的图片吓得够呛,但脊梁
同程艺龙升级疫情退改保障 团队游享特殊退订政策

同程艺龙升级疫情退改

同程艺龙官方微博宣布,受疫情影响,1月26日之后包括出境
美的集团再向湖北疫区捐款1亿元人民币 全力抗击病毒

美的集团再向湖北疫区

美的集团决定通过湖北省红十字会,向湖北疫区捐赠1亿元
香油滴鼻孔,能阻断新型冠状病毒传播?不靠谱!

香油滴鼻孔,能阻断新型

“总之,切忌轻信网上的传言,要按照官方发布的指导信息,做
最新文章
jQuery设置下拉框显示与隐藏效果的方法分析

jQuery设置下拉框显示

这篇文章主要介绍了jQuery设置下拉框显示与隐藏效果的
策略模式实现 Vue 动态表单验证的方法

策略模式实现 Vue 动

策略模式(Strategy Pattern)又称政策模式,其定义一系列的
Layui Form 自定义验证的实例代码

Layui Form 自定义验

今天小编就为大家分享一篇Layui Form 自定义验证的实
图解NodeJS实现登录注册功能

图解NodeJS实现登录注

这篇文章主要介绍了NodeJS实现登录注册功能,本文图文
基于Layui自定义模块的使用方法详解

基于Layui自定义模块

今天小编就为大家分享一篇基于Layui自定义模块的使用
layer弹出层自适应高度,垂直水平居中的实现

layer弹出层自适应高

今天小编就为大家分享一篇layer弹出层自适应高度,垂直