10、在服务器正式部署和发布上线nodejs项目。

一、上传项目代码到线上git仓库并从线上git仓库将项目clone到服务器

github相信大家都不会陌生,大家通常可以把项目通过git提交到github来实现代码的托管和版本的管理,但是github是一个崇尚开源的社区,在github上托管的项目基本都是公开的,如果托管的是私有的项目是要付费的。如果想要建立免费私有的项目,大家可以使用国内的gitoschina。http://git.oschina.net/。具体使用方法,大家可以进入他的官网进行学习研究。
我这里的实验项目只是一个demo所以就直接放github上了:https://github.com/xiaoxiekeke/myblog.git,大家可以clone下来玩玩。

10、在服务器正式部署和发布上线nodejs项目。_第1张图片
//如图,我在服务器中做了以下操作,项目就已经被clone到服务器了。(服务器中应该先安装git)
//新建node-website来存放项目代码
mkdir node-website
//进入node-website目录
cd node-website
//clone 项目到服务器
git clone https://github.com/xiaoxiekeke/myblog.git

这个时候我的服务器~/web-site/目录下就有了myblog项目。


二、使用pm2将项目部署到线上

1、首先修改项目中/config/default.js目录下的配置文件。
其中“port”为项目监听的端口号,我们这里监听的是8082。“mongodb”为连接mongo所需要配置的参数。

10、在服务器正式部署和发布上线nodejs项目。_第2张图片

2、然后在项目中用 pm2 start index.js开启node进程常驻。
10、在服务器正式部署和发布上线nodejs项目。_第3张图片

3、编辑iptables防火墙配置文件,并开启相应端口号 sudo vi /etc/iptables.up.rules
10、在服务器正式部署和发布上线nodejs项目。_第4张图片

4、重载iptables sudo iptables-restore

5、访问:http://47.52.28.218:8082/


10、在服务器正式部署和发布上线nodejs项目。_第5张图片

此时我们的博客已经部署成功,但是只能用ip地址访问


三、配置nginx映射并使"blog.xiaoxiekeke.com"域名可以直接访问到http://47.52.28.218:8082/

第二节中,我们成功的把项目部署到了线上,但只能够使用ip访问,为了使它能够通过域名被用户访问,还需要做以下操作:
1、进入nginx配置文件目录:cd /etc/nginx/conf.d/


如图,目前该目录下只有一个之前在第六章中写好的一个配置文件“xiaoke-com-8081.conf”,该配置文件是将80端口映射到8081端口,我们将其复制一份
2、复制nginx配置文件: sudo cp xiaoke-com-8081.conf blog-com-8082.conf

3、编写配置文件为:

upstream blog {
  server 127.0.0.1:8082;
}

server {
  listen 80;
  server_name blog.xiaoxiekeke.com;
  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://blog;
    proxy_redirect off;
  }
}

前提:此处我们要用的blog.xiaoxiekeke.com域名已经在第8章中使用dnspod解析过了,如果没有解析的话还需要解析一下,才能用。不了解的可参考7、8两章。


10、在服务器正式部署和发布上线nodejs项目。_第6张图片

4、编写和保存好配置文件后重启nginx服务:

10、在服务器正式部署和发布上线nodejs项目。_第7张图片

5、此时就可以通过域名访问项目了:


10、在服务器正式部署和发布上线nodejs项目。_第8张图片



四、pm2配置自动化部署

经过以上的操作,我们已经能够将项目成功能部署到服务器上了,然而每次部署的过程如果全部采用手动的话还是过于麻烦。我们需要登录服务器、pull新代码、重新安装依赖、重启服务……这些过程麻烦且容易出错,因此我们考虑采用pm2的方式实现一键自动化的部署项目,解决项目部署过程中的痛点。
1、我们在项目的根目录下新建一个ecosystem.json文件,并push到git仓库:

{
  "apps" : [{
    "name"      : "myblog",
    "script"    : "index.js",
    "env": {
      "COMMON_ENV_VAR": "true"
    },
    "env_production" :{
      "NODE_ENV": "production",
    }
  }],
  "deploy" : {
    "production" : {
      "user" : "xiaoke",
      "host" : "47.52.28.218",
      "port" : "39999",
      "repo" : "https://github.com/xiaoxiekeke/myblog.git",
      "ref"  : "origin/master",
      "path" : "/www/website/myblog",
      "ssh_options": "StrictHostKeyChecking=no",
      "post-deploy" : "npm install && pm2 startOrRestart ecosystem.json --env production",
      "env"  : {
        "NODE_ENV": "production"
      }
    }
  }
}

2、若服务器用的是“非交互式”ssh登录,则需要将服务器中~/.bashrc文件中的

#case $- in
#    *i*) ;;
#      *) return;;
#esac

注释掉,然后source .bashrc重载

3、在服务器中新建网站目录/www/website/myblog并赋予777权限:

10、在服务器正式部署和发布上线nodejs项目。_第9张图片

4、在本地执行pm2 deploy ecosystem.json production setup把git仓库的代码部署到服务器。


此时服务器目录下会出现三个文件夹:current(当前代码),share(日志等共享文件),cource(源代码)。

5、在本地部署远程服务:pm2 deploy ecosystem.json production
此时服务器会执行“ecosystem.json”配置文件中的“post-deploy”,先安装依赖然后再通过pm2启动项目。

10、在服务器正式部署和发布上线nodejs项目。_第10张图片

此时在服务器上该项目已经被启动:


10、在服务器正式部署和发布上线nodejs项目。_第11张图片

最后,附上pm2的官网,大家可以进行更深度的学习!https://keymetrics.io/

你可能感兴趣的:(10、在服务器正式部署和发布上线nodejs项目。)