[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 | bash
source ~/.bash_profile1
2
3. 使配置生效nvm --version1
2
4. 查看nvm版本nvm list-remote1
2
3
4
5. 查看可安装node版本
查看可以安装的node版本,注意`(Latest LTS: Carbon)`标识, 此标识是长期支持的最新版本nvm install v8.12.01
2
6. 安装指定版本的nodenode -v npm -v1
2
7. 确认安装结果nvm use v10.10.01
2
8. 切换版本nvm alias default v10.10.01
2
9. 设置默认版本nvm list1
2
10. 查看所有已安装的版本npm install pm2 -g1
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)