pm2 启动pm2配置文件件怎么加注释

nodejs插件之pm2
pm2 是一个带有负载均衡功能的Node应用的进程管理器.
当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载,
PM2是完美的。它非常适合IaaS结构,但不要把它用于PaaS方案(随后将开发Paas的解决方案).
备注:SaaS、PaaS和IaaS是云服务模式。
&&&&&&&&SaaS
软件即服务,例如Google的 Gmail 邮箱服务.面向应用型用户.
&&&&&&&&PaaS
平台即服务.例如Google的GAE,面向开发型用户
&&&&&&&&IaaS
基础架构即服务,例如亚马逊的AWS,IaaS对于不知道新推出的应用程序/网站会有多成功的创业公司来说非常有用
&&&&&&请参考
主要特性:
内建负载均衡(使用Node cluster 集群模块)
0秒停机重载,我理解大概意思是维护升级的时候不需要停机.
具有Ubuntu和CentOS 的启动脚本
停止不稳定的进程(避免无限循环)
控制台检测
提供 HTTP API
远程控制和实时的接口API ( Nodejs 模块,允许和PM2进程管理器交互 )
测试过Nodejs v0.11 v0.10 v0.8版本,兼容CoffeeScript,基于Linux 和MacOS.
npm install -g pm2
$ npm install pm2 -g # 命令行安装 pm2
$ pm2 start app.js -i 4 #后台运行pm2,启动4个app.js
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&#
也可以把'max' 参数传递给 start
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&#
正确的进程数目依赖于Cpu的核心数目
$ pm2 start app.js --name my-api # 命名进程
$ pm2 list # 显示所有进程状态
$ pm2 monit # 监视所有进程
$ pm2 logs # 显示所有进程日志
$ pm2 stop all # 停止所有进程
$ pm2 restart all # 重启所有进程
$ pm2 reload all # 0秒停机重载进程 (用于 NETWORKED 进程)
$ pm2 stop 0 # 停止指定的进程
$ pm2 restart 0 # 重启指定的进程
$ pm2 startup # 产生 init 脚本 保持进程活着
$ pm2 web # 运行健壮的 computer API endpoint ()
$ pm2 delete 0 # 杀死指定的进程
$ pm2 delete all # 杀死全部进程
运行进程的不同方式:
$ pm2 start app.js -i max # 根据有效CPU数目启动最大进程数目
$ pm2 start app.js -i 3 # 启动3个进程
$ pm2 start app.js -x #用fork模式启动 app.js 而不是使用 cluster
$ pm2 start app.js -x -- -a 23 # 用fork模式启动 app.js 并且传递参数 (-a
$ pm2 start app.js --name serverone # 启动一个进程并把它命名为 serverone
$ pm2 stop serverone # 停止 serverone 进程
$ pm2 start app.json # 启动进程, 在 app.json里设置选项
$ pm2 start app.js -i max -- -a 23 #在--之后给 app.js 传递参数
$ pm2 start app.js -i max -e err.log -o out.log # 启动 并
生成一个配置文件
你也可以执行用其他语言编写的app ( fork 模式):
$ pm2 start my-bash-script.sh -x --interpreter bash
$ pm2 start my-python-script.py -x --interpreter python
0秒停机重载:
这项功能允许你重新载入代码而不用失去请求连接。
仅能用于web应用
运行于Node 0.11.x版本
运行于 cluster 模式(默认模式)
$ pm2 reload all
CoffeeScript:
$ pm2 start my_app.coffee #这就是全部
PM2准备好为产品级服务了吗?
只需在你的服务器上测试
$ git clone
$ npm install # 或者 npm install --dev ,如果devDependencies 没有安装
$ npm test
列出由pm2管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。
监视每个node进程的CPU和内存的使用情况。
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。pm2 有点坑?!! - CNode技术社区
积分: 1460
前某不知名公司项目总监,现某不知名电商平台产品总监,全能打杂。
centos 中有3个项目,用pm2启动3个项目。用pm2 list 一看,状态全是启动的。
但是其中有一个访问不了,一直报502(我设置二级域名)。之前一直怀疑是nginx配置的问题,后面又去排查端口。
结果再进程中一看,居然只有其中的2个端口,那么第三个端口呢,怀疑端口冲突,改了好几个。还是无果。
最终试了试npm 启动 ,正常启动。nginx也正常映射,网站也能正常访问了。
不知道有没有大神知道这是怎么回事呢?
最终的原因找到了。
Express 4.x 默认将启动模块分离到了./bin/www中,直接使用 supervisor 无法正常监控应用,使得开发过程中的调试非常不方便。
直接在 app.js 添加 app 模块即可。
var debug = require('debug')('my-application'); // debug模块
app.set('port', process.env.PORT || 3000); // 设定监听端口
// Environment sets...
// module.exports = 这是 4.x 默认的配置,分离了 app 模块,将它注释即可,上线时可以重新改回来
//启动监听
var server = app.listen(app.get('port'), function() {
debug('Express server listening on port ' + server.address().port);
之后就可以正常的supervisor app.js进行调试了。
如果需要彻底改变启动方式,还需要修改packages.json
&scripts&: {
&start&: &node app.js& // 此处将原本的 'node ./bin/www' 改为 'node app.js'
之后运行npm start实际就是node app.js了。
碰见过,不过我用的是kraken + pm2,网上说kraken 跟pm2不兼容,现象跟你的一样。后来google到了解决方法。在入口文件 app.js里,不做启动,把启动放到另外一个类A里,app.js 负责new A 和调用A的方法,即可。有点代理模式的想法。
那就是跟express4的模式一样。bin中有个www文件。刚刚想到能否直接去启动www文件。而不是app.js
其本身是一个数组
你的这个问题怎么解决滴 我现在也遇到同样的问题
supervisor 无法正常监控应用 ?
我的可以啊
CNode 社区为国内最专业的 Node.js 开源技术社区,致力于 Node.js 的技术研究。
服务器赞助商为
,存储赞助商为
,由提供应用性能服务。
新手搭建 Node.js 服务器,推荐使用无需备案的nodejs部署方式-pm2(一) - 推酷
nodejs部署方式-pm2(一)
目前Nodejs开发中有很多痛点,其中有一个是修改完代码以后需要我们重启服务才能看到效果。这样一次次的杀进程、重启,杀进程、重启很让人头大。程序员是最痛恨重复工作的物种,之前有了解过的同学可能知道 forever 。 forever 可以帮我们解决上面的问题,通过对资源变化的检测做到变化后自动重启。开发阶段我们使用 node file.js 来启动另外由于Nodejs的单线程,任何异常都会导致整个服务中断,这对于生产上长时间提供服务的程序来讲是不可以的, forever 可以帮我们在异常后重启,保证服务一直在线,我想这也就是它名字的由来吧。但我想说的是 forever 不够“高!大!上!”。接下来我要介绍一个足够高大上的神器–
pm2 = P (rocess) M (anager)2,是可以用于生产环境的Nodejs的进程管理工具,并且它内置一个负载均衡。它不仅可以保证服务不会中断一直在线,并且提供0秒reload功能,还有其他一系列进程管理、监控功能。并且使用起来非常简单。下面我将把我的使用过程分享出来,Nodejs应用是一个基于Express 4.x的应用,名称是 Wolverine 。
环境清单:
windows7 x64
node v5.0.0
全局安装 pm2
$ npm install pm2 -g
$ pm2 update
以前启动 Wolverine 是利用package.json的 scripts 来实现的,只需要执行 npm run start 就可以启动,配置如下:
&scripts&: {
&start&: &node ./bin/www&,
&debug&: &node debug ./bin/www&
使用 pm2 我们可以在start处配置成 pm2 ./bin/www ,命令后面支持加参数来实现watch、cluster多进程模式等功能。我不太喜欢一大串的命令,于是我使用了配置文件的方式。
在 Wolverine 的根目录,我创建了一个 processes.json 配置文件,配置文件内容如下,注释写的也很清楚了
&apps& : [{
&name& : &Wolverine&,
&script&: &./bin/www&, //程序入库
&cwd&: &./&,
&configs&,
],//需要监控的目录
&error_file&:&./logs/app-err.log&,//错误输出日志
&out_file&:&./logs/app-out.log&,
&log_date_format&:&YYYY-MM-DD HH:mm Z& //日期格式
随后,我在package.json中增加了一条
&pm2&: &pm2 start processes.json&
在启动就直接输入如下命令就好:
$ npm run pm2
看到下面的界面,就启动成功了,然后我们就可以关掉这个窗口了,服务不会因此停止,是不是高大上多了。
管理和监控
启动成功的界面会展示App name和id,这两个值很重要。当然这两个值都可以在processes.json配置文件进行配置。
打开命令行,在任何路径下,输入
$ pm2 list
就能看到启动时的图表界面,方便我们查看所有通过pm2管理的Nodejs服务。
输入,下面命令配合id或者name可以查看某一个进程的详细信息
$ pm2 show Wolverine 或者
$ pm2 show 0
内容涉及重启次数、运行时间、脚本路径、参数、日志路径、运行模式等等信息
$ pm2 monit
停止、重启等命令
$ pm2 stop [app-name|id]
#停止某一个进程,可以使用app-name或者id
$ pm2 stop all
#停止所有进程
$ pm2 restart all
#重启所有的进程
$ pm2 delete [app-name|id]#删除并停止进程
$ pm2 delete all
#删除并停止所有进程
可以进一步查看每一个服务的cpu、内存动态占用情况。
如果你一直使用 tail -f log_file.log log_error.log 来查看日志,你可能会爱上下面的这个功能。
$ pm2 logs
$ pm2 logs [app-name]
我们可以实时查看全部进程的日志,或者只查看某一个。我们甚至可以使用json格式查看日志。
$ pm2 logs --json
如果你不仅仅想监控被pm2管理的进程,还需要监控进程所运行的机器的信息,你可以使用下面这个API
pm2会启动一个叫做pm2-http-interface的进程提供web服务。你打开浏览器输入http://127.0.0.1:9615,是不是被看到的结果惊艳到了。
pm2提供的web api通过json输出了很多信息。大致结构可以看截图:
拿出你的想象力,我们可以开发一个应用来调用此api,就可以开发出一个图形界面的监控软件了。。。
已发表评论数()
请填写推刊名
描述不能大于100个字符!
权限设置: 公开
仅自己可见
正文不准确
标题不准确
排版有问题
主题不准确
没有分页内容
图片无法显示
视频无法显示
与原文不一致Java 读写Properties配置文件 - 旭东的博客 - 博客园
随笔 - 161, 文章 - 0, 评论 - 157, 引用 - 0
1.Properties类与Properties配置文件
  Properties类继承自Hashtable类并且实现了Map接口,也是使用一种键值对的形式来保存属性集。不过Properties有特殊的地方,就是它的键和值都是字符串类型。
2.Properties中的主要方法
(1)load(InputStream inStream)
&  这个方法可以从.properties属性文件对应的文件输入流中,加载属性列表到Properties类对象。如下面的代码:
Properties pro = new Properties();
FileInputStream in = new FileInputStream("a.properties");
pro.load(in);
in.close();
(2)store(OutputStream out, String comments)
&  这个方法将Properties类对象的属性列表保存到输出流中。如下面的代码:
FileOutputStream oFile = new FileOutputStream(file, "a.properties");
pro.store(oFile, "Comment");
oFile.close();
  如果comments不为空,保存后的属性文件第一行会是#comments,表示注释信息;如果为空则没有注释信息。
  注释信息后面是属性文件的当前保存时间信息。
(3)getProperty/setProperty
&  这两个方法是分别是获取和设置属性信息。
3.代码实例
&属性文件a.properties如下:
读取a.properties属性列表,与生成属性文件b.properties。代码如下:
1 import java.io.BufferedInputS
2 import java.io.FileInputS
3 import java.io.FileOutputS
4 import java.io.InputS
5 import java.util.I
6 import java.util.P
8 public class PropertyTest {
public static void main(String[] args) {
Properties prop = new Properties();
//读取属性文件a.properties
InputStream in = new BufferedInputStream (new FileInputStream("a.properties"));
prop.load(in);
///加载属性列表
Iterator&String& it=prop.stringPropertyNames().iterator();
while(it.hasNext()){
String key=it.next();
System.out.println(key+":"+prop.getProperty(key));
in.close();
///保存属性到b.properties文件
FileOutputStream oFile = new FileOutputStream("b.properties", true);//true表示追加打开
prop.setProperty("phone", "10086");
prop.store(oFile, "The New properties file");
oFile.close();
catch(Exception e){
System.out.println(e);PM2实用入门指南_nodejs_ThinkSAAS
PM2实用入门指南
PM2实用入门指南
PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单。
下面就对PM2进行入门性的介绍,基本涵盖了PM2的常用的功能和配置。
全局安装,简直不能更简单。
npm install -g pm2
pm2安装好后,会自动创建下面目录。看文件名基本就知道干嘛的了,就不翻译了。
$HOME/.pm2 will contain all PM2 related files
$HOME/.pm2/logs will contain all applications logs
$HOME/.pm2/pids will contain all applications pids
$HOME/.pm2/pm2.log PM2 logs
$HOME/.pm2/pm2.pid PM2 pid
$HOME/.pm2/rpc.sock Socket file for remote commands
$HOME/.pm2/pub.sock Socket file for publishable events
$HOME/.pm2/conf.js PM2 Configuration
挑我们最爱的express应用来举例。一般我们都是通过npm start启动应用,其实就是调用node ./bin/www。那么,换成pm2就是
注意,这里用了--watch参数,意味着当你的express应用代码发生变化时,pm2会帮你重启服务,多贴心。
pm2 start ./bin/www --watch
入门太简单了,没什么好讲的。直接上官方文档:
参数说明:
--watch:监听应用目录的变化,一旦发生变化,自动重启。如果要精确监听、不见听的目录,最好通过配置文件。
-i --instances:启用多少个实例,可用于负载均衡。如果-i 0或者-i max,则根据当前机器核数确定实例数目。
--ignore-watch:排除监听的目录/文件,可以是特定的文件名,也可以是正则。比如--ignore-watch="test node_modules "some scripts""
-n --name:应用的名称。查看应用信息的时候可以用到。
-o --output &path&:标准输出日志文件的路径。
-e --error &path&:错误输出日志文件的路径。
--interpreter &interpreter&:the interpreter pm2 should use for executing app (bash, python...)。比如你用的coffee script来编写应用。
完整命令行参数列表:
pm2 start app.js --watch -i 2
pm2 restart app.js
停止特定的应用。可以先通过pm2 list获取应用的名字(--name指定的)或者进程id。
pm2 stop app_name|app_id
如果要停止所有应用,可以
pm2 stop all
类似pm2 stop,如下
pm2 stop app_name|app_id
pm2 stop all
查看进程状态
查看某个进程的信息
[ pids]# pm2 describe 0
Describing process with id 0 - name oc-server
┌───────────────────┬──────────────────────────────────────────────────────────────┐
│ oc-server
│ /data/file/qiquan/over_the_counter/server/bin/www
│ exec cwd
│ /data/file/qiquan/over_the_counter/server
│ error log path
│ /data/file/qiquan/over_the_counter/server/logs/app-err-0.log │
│ out log path
│ /data/file/qiquan/over_the_counter/server/logs/app-out-0.log │
│ pid path
│ /root/.pm2/pids/oc-server-0.pid
│ fork_mode
│ node v8 arguments │
│ watch & reload
│ interpreter
│ restarts
│ unstable restarts │ 0
│ created at
│ T08:13:43.705Z
└───────────────────┴──────────────────────────────────────────────────────────────┘
配置文件里的设置项,跟命令行参数基本是一一对应的。
可以选择yaml或者json文件,就看个人洗好了。
json格式的配置文件,pm2当作普通的js文件来处理,所以可以在里面添加注释或者编写代码,这对于动态调整配置很有好处。
如果启动的时候指定了配置文件,那么命令行参数会被忽略。(个别参数除外,比如--env)
举个简单例子,完整配置说明请参考。
: "fis-receiver",
// 应用名称
: "./bin/www",
// 实际启动脚本
// 当前工作路径
"watch": [
// 监控变化的目录,一旦变化,自动重启
"ignore_watch" : [
// 从监控目录中排除
"node_modules",
"watch_options": {
"followSymlinks": false
"error_file" : "./logs/app-err.log",
// 错误日志路径
"out_file"
: "./logs/app-out.log",
// 普通日志路径
"NODE_ENV": "production"
// 环境参数,当前指定为生产环境
前面已经提到了,这里贴命令行,更多点击。
pm2 start app.js --watch
这里是监控整个项目的文件,如果只想监听指定文件和目录,建议通过配置文件的watch、ignore_watch字段来设置。
在实际项目开发中,我们的应用经常需要在多个环境下部署,比如开发环境、测试环境、生产环境等。在不同环境下,有时候配置项会有差异,比如链接的数据库地址不同等。
对于这种场景,pm2也是可以很好支持的。首先通过在配置文件中通过env_xx来声明不同环境的配置,然后在启动应用时,通过--env参数指定运行的环境。
环境配置声明
首先,在配置文件中,通过env选项声明多个环境配置。简单说明下:
env为默认的环境配置(生产环境),env_dev、env_test则分别是开发、测试环境。可以看到,不同环境下的NODE_ENV、REMOTE_ADDR字段的值是不同的。
在应用中,可以通过process.env.REMOTE_ADDR等来读取配置中生命的变量。
"NODE_ENV": "production",
"REMOTE_ADDR": "/"
"env_dev": {
"NODE_ENV": "development",
"REMOTE_ADDR": "/"
"env_test": {
"NODE_ENV": "test",
"REMOTE_ADDR": "/"
启动指明环境
假设通过下面启动脚本(开发环境),那么,此时process.env.REMOTE_ADDR的值就是相应的
,可以自己试验下。
pm2 start app.js --env dev
命令如下,表示开启三个进程。如果-i 0,则会根据机器当前核数自动开启尽可能多的进程。
pm2 start app.js -i 3 # 开启三个进程
pm2 start app.js -i max # 根据机器CPU核数,开启对应数目的进程
参考文档:
除了可以打开日志文件查看日志外,还可以通过pm2 logs来查看实时日志。这点对于线上问题排查非常重要。
比如某个node服务突然异常重启了,那么可以通过pm2提供的日志工具来查看实时日志,看是不是脚本出错之类导致的异常重启。
指令tab补全
运行pm2 --help,可以看到pm2支持的子命令还是蛮多的,这个时候,自动完成的功能就很重要了。
运行如下命令。恭喜,已经能够通过tab自动补全了。细节可参考。
pm2 completion install
source ~/.bash_profile
开机自动启动
可以通过pm2 startup来实现开机自启动。细节可。大致流程如下
通过pm2 save保存当前进程状态。
通过pm2 startup [platform]生成开机自启动的命令。(记得查看控制台输出)
将步骤2生成的命令,粘贴到控制台进行,搞定。
传入node args
直接上例子,分别是通过命令行和配置文件。
pm2 start app.js --node-args="--harmony"
配置文件:
"name" : "oc-server",
"script" : "app.js",
"node_args" : "--harmony"
假设是在centos下,那么运行如下命令,搞定。强烈建议运行完成之后,重启机器,看是否设置成功。
[ option_analysis]# pm2 save
[ option_analysis]# pm2 startup centos
[PM2] Generating system init script in /etc/init.d/pm2-init.sh
[PM2] Making script booting at startup...
[PM2] /var/lock/subsys/pm2-init.sh lockfile has been added
[PM2] -centos- Using the command:
su -c "chmod +x /etc/init.d/pm2-init. chkconfig --add pm2-init.sh"
[PM2] Done.
[ option_analysis]# pm2 save
[PM2] Dumping processes
可参考官方文档,配置也不复杂,用到的时候再来填写这里的坑。TODO
官方文档:
监控(monitor)
运行如下命令,查看当前通过pm2运行的进程的状态。
看到类似输出
[ server]# pm2 monit
? PM2 monitoring (To go further check out https://app.keymetrics.io)
? PM2 monitoring (To go further check o[|||||||||||||||
] 196.285 MB
● fis-receiver
[1] [fork_mode]
] 65.773 MB
[2] [fork_mode]
] 74.426 MB
● oc-server
[3] [fork_mode]
] 57.801 MB
● pm2-http-interface
[4] [fork_mode]
● start-production
[5] [fork_mode]
内存使用超过上限自动重启
如果想要你的应用,在超过使用内存上限后自动重启,那么可以加上--max-memory-restart参数。(有对应的配置项)
pm2 start big-array.js --max-memory-restart 20M
官方文档:
$ pm2 save # 记得保存进程状态
$ npm install pm2 -g
$ pm2 update
pm2 + nginx
无非就是在nginx上做个反向代理配置,直接贴配置。
upstream my_nodejs_upstream {
server 127.0.0.1:3001;
listen 80;
server_name my_nodejs_
root /home/www/project_
location / {
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_
proxy_set_header Host $http_
proxy_set_header X-NginX-P
proxy_http_version 1.1;
proxy_set_header Upgrade $http_
proxy_set_header Connection "upgrade";
proxy_max_temp_file_size 0;
proxy_pass http://my_nodejs_upstream/;
proxy_read_timeout 240s;
官方文档:
在线监控系统
收费服务,使用超级简单,可以方便的对进程的服务情况进行监控。可以试用下,地址在。
这里贴个项目中试用的截图。
pm2编程接口
如果想把pm2的进程监控,跟其他自动化流程整合起来,pm2的编程接口就很有用了。细节可参考官方文档:
模块扩展系统
pm2支持第三方扩展,比如常用的log rotate等。可参考。
pm2的文档已经写的很好了,学习成本很低,即使是没用过pm2的小伙伴,基本上照着getting started的例子就可以把项目给跑起来,所以文中不少地方都是建议直接参看官方文档。
。。。内容来源:
PHP开发框架
开发工具/编程工具
服务器环境
ThinkSAAS商业授权:
ThinkSAAS为用户提供有偿个性定制开发服务
ThinkSAAS将为商业授权用户提供二次开发指导和技术支持
让ThinkSAAS更好,把建议拿来。
开发客服微信}

我要回帖

更多关于 ini配置文件注释 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信