pm2 用法之 ecosystem 部署 nodejs 项目
一、配置部署脚本文件
部署参考 http://blog.poetries.top/2018/11/18/react-ssr-next-deploy/
在项目根目录添加 pm2
的部署脚本文件 ecosystem.json
{
"apps": [
"name": "movie", //对应 Nginx 上的配置
"script": "app.js", //入口文件
"env": {
"COMON_VARIABLE": "true"
},
"env_production": {
"NODE_ENV": "production"
}
],
"deploy": {
"production": {
"user": "poetries", //Nginx 服务器上的 username
"host": ["120.120.14.21"], // 服务器地址
"port": "3922",
"ref": "origin/master", //从指定的分支拉取代码
"repo": "git@github.com:poetries/poetries.github.io.git",
"path": "/www/movie/production",//发布到服务器指定的目录下
"ssh_options": "StrictHostKeyChecking=no",
//构建在发布
"post-deploy": "npm install --registry=https://registry.npm.taobao.org && grunt build && pm2 startOrRestart ecosystem.json --env production",
"env": {
"NODE_ENV": "production"
}
}
}
}
二、配置 Nginx 的 server
在 nginx
安装目录下的 vhost
中新建一个 xx-3000.conf
的配置文件
upstream movie { // website 项目的目录名称
server 127.0.0.1:3000; // 服务器上的本地启动入口
}
// 配置 server
server {
listen 80;
server_name movie.poetries.top; //指向的域名
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-Nginx-Proxy true;
proxy_pass http://movie; // 对应上面的目录
proxy_redirect off;
}
// 处理静态资源
location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|js|pdf|txt) {
root /www/movie/public; //静态资源路径
}
}
三、开启防火墙
Ubuntu 的设置
- 打开
sudo vi /etc/iptables.up.rules
- 生效
sudo iptables-restore < /etc/iptables.up.rules
# movie
-A INPUT -s 127.0.0.1 -p tcp --destination-port 3001 -m state ESTABLISHED -j ACCEPT
-A OUTPUT -s 127.0.0.1 -p tcp --destination-port 3001 -m state ESTABLISHED -j ACCEPT
四、部署命令
pm2 deploy ecosystem.json production setup
初始化pm2 deploy ecosystem.json production
部署
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: 梳理 Immutable 常用 API
下一篇: 彻底找到 Tomcat 启动速度慢的元凶
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论