[TOC]
新项目需要使用node.js。 记录一下node.js和npm安装过程.
1. Mac本地安装Node.js
下载之前的node.js项目, 用phpstorm打开后报语法错误. 检查phpstorm的nodejs插件已启用. 判断是node.js环境未配置.
Mac安装配置node.js和npm.- 访问node.js官网下载列表(https://nodejs.org/en/download/) - 下载推荐的node-v8.11.3.pkg包, 点击并根据提示进行安装. 安装完成后会显示软件的安装版本和安装位置, 如下所示. - 1 
 2
 3- • Node.js v8.11.3 to /usr/local/bin/node 
 • npm v5.6.0 to /usr/local/bin/npm
 Make sure that /usr/local/bin is in your $PATH.- 可在控制台输入以下命令查看安装版本. - 1 
 2
 3
 4- $ node -v 
 v8.11.3
 $ npm -v
 5.6.0
- 更换为淘宝的NPM镜像(http://npm.taobao.org) - 1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15- //查看当前镜像 
 $ npm get registry
 https://registry.npmjs.org/
 //更换为淘宝的镜像 -- 此方案安装cnpm, 不影响之前的npm
 sudo npm install -g cnpm --registry=https://registry.npm.taobao.org
 //添加成功后查看cnpm版本信息
 $ cnpm -v
 cnpm@6.0.0 (/usr/local/lib/node_modules/cnpm/lib/parse_argv.js)
 npm@6.2.0 (/usr/local/lib/node_modules/cnpm/node_modules/npm/lib/npm.js)
 node@8.11.3 (/usr/local/bin/node)
 npminstall@3.10.0 (/usr/local/lib/node_modules/cnpm/node_modules/npminstall/lib/index.js)
 prefix=/usr/local
 darwin x64 17.4.0
 registry=https://registry.npm.taobao.org
- 导入express框架及其相关模块 - 1 
 2- //安装express并将其保存到依赖列表中 
 cnpm install express --save
- 查看已安装过的包 - 1 
 2
 3
 4- //全局查看 
 npm list -g --depth 0
 //查看本地
 npm list --depth 0
- 卸载本地package - 1 - npm uninstall <package-name> 
- 创建package.json - 1 - 使用 npm init 即可在当前目录创建一个 package.json 文件: - 输入 - npm init后会弹出一堆问题,我们可以输入对应内容,也可以使用默认值。在回答一堆问题后输入- yes就会生成图中所示内容的- package.json文件。- 如果嫌回答这一大堆问题麻烦,可以直接输入 - npm init --yes跳过回答问题步骤,直接生成默认值的- package.json文件:
2. centos6.5 nvm 安装升级nodejs
- 查看服务器nodejs版本 - 1 
 2
 3
 4- # node -v 
 v6.10.3
 # npm -v
 3.10.10
- 服务器以前版本是通过nvm安装管理的 - 通过nvm安装升级指定nodejs - 1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15- //查看可用node版本 
 # nvm ls-remote
 v8.11.1
 v8.11.2
 -> v8.11.3
 v9.0.0
 
 //安装v8.11.3版本
 nvm install v8.11.3
 //安装完成后使用新版
 nvm use v8.11.3
 //卸载旧版本(只有在该版本未使用状态可卸载)
 nvm uninstall v6.10.3
 //将此版本设为默认
 nvm alias default v6.10.2
3. centos7 使用nvm方式安装nodejs
- 安装nvm 最新版本是0.33.11 git地址 
- # curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh | bash or Wget: # wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.11/install.sh | bashsource ~/.bash_profile- 1 
 2
 3. 使配置生效nvm --version- 1 
 2
 4. 查看nvm版本nvm list-remote- 1 
 2
 3
 4
 5. 查看可安装node版本
 查看可以安装的node版本,注意`(Latest LTS: Carbon)`标识, 此标识是长期支持的最新版本nvm install v8.12.0- 1 
 2
 6. 安装指定版本的nodenode -v npm -v- 1 
 2
 7. 确认安装结果nvm use v10.10.0- 1 
 2
 8. 切换版本nvm alias default v10.10.0- 1 
 2
 9. 设置默认版本nvm list- 1 
 2
 10. 查看所有已安装的版本npm install pm2 -g- 1 
 2
 3
 4
 5
 6
 7
 8
 ### 4. pm2使用(进程管理器)
 pm2 是一个带有负载均衡功能的Node应用的进程管理器.
 [pm2官网](https://pm2.io/doc/en/runtime/quick-start/)
 以npm方式安装**pm2** (全局安装)$ pm2 start app.js # 启动app.js应用程序- 1 
 2
 以下是pm2常用的命令行
$ pm2 start app.js -i 4 # cluster mode 模式启动4个app.js的应用实例 # 4个应用程序会自动进行负载均衡
$ pm2 start app.js –name=”api” # 启动应用程序并命名为 “api”
$ pm2 start app.js –watch # 当文件变化时自动重启应用
$ pm2 start script.sh # 启动 bash 脚本
$ pm2 list # 列表 PM2 启动的所有的应用程序
$ pm2 monit # 显示每个应用程序的CPU和内存占用情况
$ pm2 show [app-name] # 显示应用程序的所有信息
$ pm2 logs # 显示所有应用程序的日志
$ pm2 logs [app-name] # 显示指定应用程序的日志
$ pm2 flush
$ pm2 stop all # 停止所有的应用程序
$ pm2 stop 0 # 停止 id为 0的指定应用程序
$ pm2 restart all # 重启所有应用
$ pm2 reload all # 重启 cluster mode下的所有应用
$ pm2 gracefulReload all # Graceful reload all apps in cluster mode
$ pm2 delete all # 关闭并删除所有应用
$ pm2 delete 0 # 删除指定应用 id 0
$ pm2 scale api 10 # 把名字叫api的应用扩展到10个实例
$ pm2 reset [app-name] # 重置重启数量
$ pm2 startup # 创建开机自启动命令
$ pm2 save # 保存当前应用列表
$ pm2 resurrect # 重新加载保存的应用列表
$ pm2 update # Save processes, kill PM2 and restore processes
$ pm2 generate # Generate a sample json configuration file
$ pm2 deploy app.json prod setup # Setup “prod” remote server
$ pm2 deploy app.json prod # Update “prod” remote server
$ pm2 deploy app.json prod revert 2 # Revert “prod” remote server by 2
| 1 | 
 | 
pm2 install pm2-intercom
| 1 | 
 | 
 “categories”:{
    “default”:{“appenders”:[“console”,”log_info”],”level”:”info”},
    “logInfo”:{“appenders”:[“console”,”log_info”],”level”:”info”},
    “logErr”:{“appenders”:[“console”,”log_error”],”level”:”error”}
  },
  “pm2”: true
参考链接:
https://github.com/xiaozhongliu/node-api-seed/blob/master/util/logger.js
[pm2 logging problem with multiple applications](https://github.com/log4js-node/log4js-node/issues/547)
[集群模式PM2+Log4js log写入失败问题](https://juejin.im/entry/5a0cf3276fb9a0450167814f)