八、阿里云服务器 git pm2 部署

我们上传服务器的公钥到 git 仓库

cat ~/.ssh/id_rsa.pub

复制,去 github 的设置中添加公钥,

image

clone 一个项目

公钥上传到 github 后,我们的服务器就有这个 github 账户的权限了,让我们来 clone 一个项目吧。

cd ~

mkdir website

cd website

git clone git@github.com:18810666595/nodetest.git

clone 成功啦,ls 查看到了项目文件目录

image

pm2

pm2 工具能够守护 nodejs 服务,能实现平滑重启,代码自动更新,以及从本地到线上的部署。

关于 pm2 部署的文档可以去官网查看 pm2官网 http://pm2.keymetrics.io/

pm2 部署步骤:

  • 在本地的 git 仓库下,新建一个 ecosystem.json 文件

添加配置信息

{
  "apps": [
    {
      "name": "nodetest",
      "script": "app.js",
      "env": {
        "COMMON_VARIABLE": "true"
      },
      "env_production": {
        "NODE_ENV": "production"
      }
    }
  ],
  "deploy": {
    "production": {
      "user": "cg",
      "host": ["47.94.198.140"],
      "port": "22",
      "ref": "origin/master",
      "repo": "git@github.com:18810666595/nodetest.git",
      "path": "/www/website/production",
      "ssh_options": "StrictHostKeyChecking=no",
      "env": {
        "NODE_ENV": "production"
      }
    }
  }
}
  • 切换到阿里云服务器,创建 /www/nodetest 文件目录(远程)
sudo mkdir /www

cd /www

sudo mkdir nodetest
  • 让 pm2 连上服务器,自动部署任务
pm2 deploy ecosystem.json production setup

发现连接失败了,这是因为用户 cg 的权限不够,无权操作位于根路径的 /www 文件夹

image

修改用户 cg 的权限

切换到阿里云服务器,修改 /www/nodetest/ 文件对用户 cg 的权限为可读、可写、可执行。(远程)

sudo chmod 777 /www/nodetest/

再次让 pm2 连上服务器,自动部署任务(本地)

切换到本地命令行,再次执行 pm2 的自动部署

pm2 deploy ecosystem.json production setup

哈哈, success 成功啦


image

去服务器上检查一下吧

切换到阿里云服务器(远程)

cd /www/nodetest/production

ls

可以看到有三个文件夹,current, shared, source

  • current: 当前服务运行的文件夹
  • shared: 日志文件等共享数据
  • source: 克隆下来的源代码
image

进入 current 文件夹查看,发现就是我们 push 到 github 的文件。

image

本地控制远端代码更新、服务重启

pm2 部署项目的原理:

  1. 通过本地的 pm2 工具在本地命令行登录服务器,
  2. 通知服务器从 github 拉取到到服务器,部署到相应的文件夹中。

pm2 部署项目

  • 我们先把 ecosystem.json 配置文件也 push 到 github 上。

  • 然后执行命令让 pm2 自动部署

pm2 deploy ecosystem.json production

发现失败了,阿里云服务器上没有 pm2 这个指令

image

这是因为 pm2 在服务器上使用的是非交互的 ssh 连接方式。

切换到服务器

切换到服务器(远程)

vi .bashrc

把下面三项注释掉(加 #)


image
source .bashrc

如果出错,就看这篇 stackoverflow

回到本地终端

执行命令让 pm2 自动部署。

pm2 deploy ecosystem.json production

成功啦,哈哈!

image

去服务器上 pm2 list 查看进程,也能查看到

image

修改 nginx 配置信息,可以通过域名访问到这个网页

切换到阿里云服务器(远程)

cd /etc/nginx/conf.d/

sudo vi test-chengong-shop-3999.conf
    //增加配置项

配置参数为

upstream nodetest {
  server 127.0.0.1:3999;
}

server {
  listen 80;
  server_name test.chengong.shop;

  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://nodetest;
    proxy_redirect off;
  }
}

我们去浏览器访问 test.chengong.shop 域名,发现 502 报错

image

这是因为 iptables 防火墙禁止了 3999 端口的请求。

修改 iptables 的配置

sudo vi /etc/iptables.up.rules

增加两条配置,允许 3999 端口的访问

image

重启 iptables

sudo iptables-restore < /etc/iptables.up.rules

刷新我们的浏览器,或者再次访问 test.chengong.sh op 域名,发现服务启动成功啦!!

image

将本地的改动同步到线上

我们的网站服务跑在了服务器里,如果我们的本地项目做了修改,如何同步到线上呢? 三步走

  1. 修改本地项目
  2. push 本地代码到 github
  3. 执行 pm2 部署指令(在本地执行)
pm2 deploy ecosystem.json production

修改成功啦!

image

使用 npm 的 script 脚本命令实现自动化的上传到 github 并 执行 pm2 同步更新服务器远端代码。

在本地项目目录下,初始化一个 package.json 文件

npm init

一路回车默认,项目目录下就生成了一个 package.json 文件,编辑它,在 script 这一项中添加一条指令 update,注意上一条指令最后要加逗号 ,

"scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "update": "git add . && git commit -am \"update\" && git push && pm2 deploy ecosystem.json production"
  }
image

这样我们就能用 npm 指令实现自动化一条龙服务了,在命令行中,输入

npm run update

可以看到自动进行了上传到 github,并且自动执行 pm2 更新同步到远程服务器。

image

我们去浏览器刷新页面,或者再次访问 test.chengong.shop 域名,可以看到自动更新了,以后修改了本地项目,只要执行

npm run update

这个指令就自动一条龙了

image
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,656评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,130评论 25 707
  • 你发现,当一位团队成员看起来似乎动力不足,你担心这不仅会影响他自己的绩效,而且若置之不理,还会影响团队其他成员。 ...
    禾光阅读 929评论 0 0
  • 前几天,一位宝妈跟童妈讲述了宝宝发烧的全过程,觉得这位机智的宝妈有很多做法是值得大家学习的,这中间童年时光可起了不...
    雪域狼踪阅读 1,996评论 0 0
  • 通过这一周的时间开销记录练习,我认识时间开销记录有两个很明显的好处: 1.通过时间开销记录可以了解自己在不同工作任...
    心一书简阅读 847评论 0 1