Node App 部署

2017-11-13 16:39:11 +08:00
 Johnsen

Node App 部署

原文地址

环境 (System):

CentOS 7

服务器可视化管理工具( GUI )

MacOS 系统推荐使用 Cyberduck (小黄鸭)

Windows 系统推荐使用 FileZilla

准备 (Requirement)

安装 (Install)

一般在 Linux 系统中安装程序有三种方式:

  1. 下载源码,手动编译
  2. 直接下载二进制文件
  3. 用 yum 安装

这里推荐用第二种。

Install git

如果系统有自带的 git,可执行 yum remove -y git 删除

  1. 安装倚赖:

    yum install -y curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils-MakeMaker
    
  2. 前往 github 下载安装包,拷贝至 /usr/src(拷贝可通过可视化工具直接将相应文件拖入目标文件夹),或者直接用 wget:

    cd /usr/src
    yum install -y wget
    wget https://www.kernel.org/pub/software/scm/git/git-2.10.2.tar.gz
    tar xvzf git-2.10.2.tar.gz
    
  3. make 安装:

    make prefix=/usr/local all
    make prefix=/usr/local install
    
  4. 检查 git 是否安装成功:

    git --version
    

安装 node 和 npm:

  1. 前往 node official site 下载对应的编译好的 Linux 源码,或者直接用 wget 下载:

    cd /usr/src
    wget https://nodejs.org/dist/v6.10.3/node-v6.10.3-linux-x64.tar.gz
    tar xvf node-v6.10.3-linux-x64.tar.gz
    
  2. 创建软链接至 /usr/local/bin

    ln -s /usr/src/node-v6.10.3-linux-x64/bin/node /usr/local/bin/node
    ln -s /usr/src/node-v6.10.3-linux-x64/bin/npm /usr/local/bin/npm
    
  3. 检查 node 与 npm 是否生效

    node -v
    npm -v
    
  4. 接下来要配置一下 npm,将 npm 的默认全局安装路径自定义到 /$HOME/.node:

    npm config set prefix $HOME/.node
    
  5. 添加国内 npm 淘宝镜像:

    npm config set registry https://registry.npm.taobao.org/
    
  6. 配置系统路径,使 npm 全局安装的模块命令行 bin 生效:

    echo "export PATH=$PATH:$HOME/.node/bin" >> ~/.bashrc
    source ~/.bashrc
    

安装 pm2:

npm install -g pm2

布署 (Deploy)

布署分为不用 git 和基于 git 两种方式。前者主要是用于 git 代码网络属于内网的环境下。

不用 git 的话,下载 git 项目的 tag 包或者将项目文件直接拷贝至目标主机。

不基于 git 部署

  1. 安装依赖

    // 安装 node 倚赖包
    npm install --production
    
  2. 运行项目

    // node 启动,pm2 启动下面有详解
    node app.js
    

推荐使用 git

为了更好的版本管理与更轻松的解决版本倚赖,推荐使用 git。

git 的传输协议有 https 和 ssh 两种,我们采用更加安全快速的后者。服务器只需 git 的只读权限,因此不必配置 git user,只需生成 ssh key 做为项目的 deploy key ( gitlab 项目右上角的菜单中选择 "Deploy Keys",在此添加服务器的公钥 "id_rsa.pub" 中的内容)。

(ps. 关于如何生成 ssh key,可参见此,这里要输入的邮箱改为服务器名即可)。

  1. 接下来 clone 项目代码至服务器:

    git clone git@git.cairenhui.com:<GROUP>/<PROJECT>.git <NODE_APP_DIR>
    

注:尖括号内的为变量

  1. 检出版本

    // 查看当前所有版本
    git tag
    
    // 切换到指定版本,这里的 <TAG> 是演示,比如可以是 1.0.0
    git checkout <TAG>
    
  2. 安装倚赖:

    // 如果没用到 bower,跳过此步骤
    bower install --allow-root
    
    // 安装 node 倚赖包
    npm install --production
    

注:不采用 git 布署的话,只需执行最后一步

至此,无论是否使用 git,布署都已完成。

运行 (Run)

在项目根目录下,运行 pm2 start pm2.json 即可。

pm2.json 中的 name 字段为 App name,pm2 可以全局地操作它:pm2 stop <APP_NAME>

另外有几个比较有用的命令:

更多的命令用法请查看: https://github.com/Unitech/pm2#main-features

更新或回滚 (Update/Rollback)

  1. 不使用 git:之前已提到过,直接在 gitlab 上下载 tag 包,解压缩覆盖至服务器

  2. 使用 git:先通过 git 获取更新

    git fetch origin --tags
    

    再切换:

    git checkout <NEW_TAG>
    

    回滚也非常简单:

    git checkout <PREV_TAG>
    

Nginx 反向代理

Nginx 入门参考材料前端工程师学习 Nginx 入门篇

执行完以上步骤,假设你的项目启在localhost:3000,想通过 www.yourdomain.com 来访问,需要通过如下步骤配置(以阿里云域名为例):

   server {
       listen 80;
       server_name www.yourdomain.com;
       root /var/www/;
       location / {
           # 反向代理我们通过 proxy_pass 字段来设置
           # 也就是当访问 www.yourdomain.com 的时候经过 Nginx 反向代理到服务器上的 http://127.0.0.1:3000
           proxy_pass http://127.0.0.1:3000;
           proxy_set_header   Host   $host:$server_port;
           proxy_set_header   X-Real-IP   $remote_addr;
           client_max_body_size    100m;
           proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
       }
   }
2019 次点击
所在节点    程序员
4 条回复
halfcrazy
2017-11-13 16:57:02 +08:00
也可以直接在你服务器上创建一个 bare 的仓库,设置 hook 去做服务器上的发布。这样能 push 到服务器上就自动发布了。还可以用 fabric ansible 这类工具写发布脚步。连上服务器做手动发布还是太原始了
winglight2016
2017-11-13 17:40:32 +08:00
我看完了也没搞明白在安装什么?就是搭 node 运行环境吗?
GooMS
2017-11-13 17:40:48 +08:00
也可以用 CI 简单的自动部署
sarices
2017-11-13 17:52:23 +08:00
建议楼主用 jenkins+docker,或者将 jenkins 换成其他

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/406025

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX