参考文章:
使用pm2部署项目提高工作效率 https://www.jianshu.com/p/51bf8cf5227c?from=groupmessage
1 使用码云的git仓库保存代码 https://gitee.com/
首先建立代码库-->然后复制本地的用户主目录下的.ssh/id_rsa.pub
文件的内容粘贴进去-->生成公钥;
然后把本地代码关联到mayun上
然后开发服务器,复制公钥:
然后把这段代码放在码云的公钥中:
这样服务器也就有权限获取码云上的代码了
注意的是要在服务器上安装git: sudo apt-get install git
1 首先在服务器上把码云上的代码clone下来 git clone xxxx (和平时的git操作命令一样)
PS:
方法2、本地初始化一个仓库,设置远程仓库地址后再做push
和方法1的差别,在于先创建仓库。
$ git init
$ git remote add origin https://gitee.com/用户个性地址/HelloGitee.git
上面的代码是,在本地新建的文件,然后设置远程的仓库地址,一般来说我习惯先在远程设置仓库,然后clone下来初始化的仓库,再把代码放进去,所以不需要上面的步骤
==============
不使用ssh方法,如果使用的是http,是不是就不用设置ssh的一些公钥了?这样在服务器端clone http的代码也不需要公钥了?
最终的效果是在服务器上clone代码库。
PM2的地址: http://pm2.keymetrics.io/
查看其文档:http://pm2.keymetrics.io/docs/usage/pm2-doc-single-page/
目的:在服务器上使用pm2部署代码:
http://pm2.keymetrics.io/docs/usage/deployment/
首先在服务器端新建www/website文件夹: sudo mkdir website
在本地代码的根目录下新建配置文件:ecosystem.json
{ "apps":[{ "name": "website", //部署的应用的名字 "script": "app.js",//启动的入口脚本 "env": { "COMMON_VARIABLE": "true"//启动时传入的变量 }, // Environment variables injected when starting with --env production // http://pm2.keymetrics.io/docs/usage/application-declaration/#switching-to-different-environments "env_production" : { "NODE_ENV": "production" //生产环境的变量 } }], // Deployment part // Here you describe each environment "deploy" : { //部署的任务 "production" : { "user" : "imooc_manager", //服务器上用来发布的用户名 // Multi host is possible, just by passing IPs/hostname as an array "host" : ["212.83.163.1", "212.83.163.2", "212.83.163.3"],//主机ip "port":"39999",//端口号 // Branch "ref" : "origin/master", //指定主分支master // Git repository to clone "repo" : "[email protected]:repo.git", //仓库地址 // Path of the application on target servers "path" : "/www/website/production", //把项目部署到服务器的那个目录下 // Can be used to give options in the format used in the configura- // tion file. This is useful for specifying options for which there // is no separate command-line flag, see 'man ssh' // can be either a single string or an array of strings "ssh_options": "StrictHostKeyChecking=no", //把ssh的key校验取消掉 // To prepare the host by installing required software (eg: git) // even before the setup process starts // can be multiple commands separated by the character ";" // or path to a script on your local machine "pre-setup" : "apt-get install git", // Commands / path to a script on the host machine // This will be executed on the host after cloning the repository // eg: placing configurations in the shared dir etc "post-setup": "ls -la", // Commands to execute locally (on the same machine you deploy things) // Can be multiple commands separated by the character ";" "pre-deploy-local" : "echo 'This is a local executed command'" // Commands to be executed on the server after the repo has been cloned "post-deploy" : "npm install && pm2 startOrRestart ecosystem.json --env production" //项目发布到服务器上执行的命令
// Environment variables that must be injected in all applications on this env "env" : { "NODE_ENV": "production" } } } }
首先把该文件git--push到远程代码库中
然后在本地项目中运行: pm2 deploy ecosystem.json production setup // 让pm2 连接上服务器,第一次部署
其中 production 是ecosystem.json 中的配置参数名字
执行命令后发现失败:setup paths failed 是因为该用户在服务器端的website文件夹上没有新建文件的权限,
在服务器上执行 sudo chmod 777 website //给当前用户的website文件夹设置权限为 可读写可操作
切换到服务器上发现 website/production文件夹下多了三个文件夹
current/ shared/ source/
其中
current 是当前服务所运行的文件夹
shared 是日志文件等共享的数据
source 是clone下来的源代码
然后在本地执行: pm2 deploy ecosystem.json production //运行
首先在本地控制台登陆服务器,然后通过本地的pm2的配置文件ecosystem.json
和命令: pm2 deploy ecosystem.json production setup
通知服务器在远程代码库中clone代码,
并部署到服务器上相应的文件夹中,然后在发布部署。
如果依赖与数据库的话,一定要保证在服务器上能够让数据库跑起来
但是通常会遇到下面的错误:
报错pm2在服务器上找不到,原因是因为它在服务器上用的是非交互的形式。
所以切换到服务器端,在根目录下编辑.bash文件:
cd //cd不带参数就是切换到根目录上 vi .bashrc //编辑 .bashrc文件
加上#号,保存后退出
然后通过命令加载文件 source .bashrc
然后重新切换到本地终端再次执行:pm2 deploy ecosystem.json production 进行发布
启动服务后有以下样子表示成功:
执行 pm2 list。可以查看当前的list应用
最后要
1 修改域名指向
2 修改nginx配置文件,让nginx识别域名之后,转发到服务器上的3000端口(因为该项目是用在了3000端口)
cd /etc/nginx/conf.d
ls
sudo vi imooc-com-8081.conf
把上面红框中的内容改成下面:
然后通过 sudo nginx -s reload 重启nginx。
最后设置防火墙可以访问3000端口!!!!!
sudo vi /etc/iptables.up.rules
然后重启防火墙: sudo iptbles-restore < /etc/iptables.up.rules
PS: 也可以在阿里云的控制台上设置: https://help.aliyun.com/knowledge_detail/39922.html?spm=5176.13394938.0.0.2bda3ce4vcGqJY
然后就可以在服务器上访问该域名了。
===============
此外,修改代码后如何部署呢?
1.本地修改代码
2.上传到git库
3. 执行命令: pm2 deploy ecosystem.json production
刷新浏览器即可!
----------
部署新的项目,该项目带有数据库,
1 首先配置域名:这样用 movie.iblack7.com 来进行访问
2 确认新项目的端口是3001,和之前的3000用的是不同的端口
3. 修改数据库
var mongoose = require('mongoose); //imooc_movie_runner 表示数据库用户名 //F**k9001$ 数据库的密码 //访问数据库的ip地址,因为是本地访问的,所以是 127.0.0.1:19999(数据库的端口号,这里做过修改,所以是19999) //imooc-movie 是数据库的名字 var dbUrl = 'mongodb://imooc_movie_runner:F**[email protected]:19999/imooc-movie' if(env === 'development'){ dbUrl = 'mongodb://localhost/imooc-movie' } mongoose.connect(dbUrl)
4 新建 ecosystem.json 文件:
{ "apps":[{ "name": "Movie", //部署的应用的名字,修改了这里 "script": "app.js", "env": { "COMMON_VARIABLE": "true" }, "env_production" : { "NODE_ENV": "production" } }], "deploy" : { "production" : { "user" : "imooc_manager", "host" : ["212.83.163.1"], "port":"39999", "ref" : "origin/master", "repo" : "[email protected]:repo.git",//修改仓库地址,修改了这里 "path" : "/www/Movie/production", //把项目部署到服务器的哪个目录下,修改了这里 "ssh_options": "StrictHostKeyChecking=no", "pre-setup" : "apt-get install git", "post-setup": "ls -la", "pre-deploy-local" : "echo 'This is a local executed command'" "post-deploy" : "npm install && pm2 startOrRestart ecosystem.json --env production" //项目发布到服务器上执行的命令 "env" : { "NODE_ENV": "production" } } } }
所以对应的要在服务器上新建一个movie的文件夹:
cd /www ls sudo mkdir movie sudo chmod 777 -R movie //给当前用户授权
然后修改nginx的配置文件:新增一个movie的配置文件,复制原来的文件:
修改新增的配置文件:
sudo vi movie-iblack7-com-3001.conf
保证本地修改代码提交之后
最后在本地执行:
pm2 deploy ecosystem.json production setup //第一次部署
pm2 deploy ecosystem.json production
发现movie重启了9次,说明有问题:
执行 pm2 logs 查看日志,发现mongodb连接错误:
首先停止掉该服务 pm2 stop Movie
在本地修改安装更新依赖后,重新部署: pm2 deploy ecosystem.json production
修改防火墙,允许从 nginx 转发的movie请求,转发到后端的3001端口
vi /etc/iptables.up.rules //修改防火墙配置
然后重启防火墙: sudo iptbles-restore < /etc/iptables.up.rules
重启nginx: sudo nginx -s reload
========================
最后把协议改成https在视频的最后一章