koa2静态服务器的搭建以及pm2一键部署入门

使用某一技术栈多了,自然而然就要考虑属于自己常用的脚手架了,毕竟搬砖也要自己总结一套最有效率的搬砖方法。

本人目前使用较多的是react方面的技术栈,react官方推荐使用的是create-react-app,本文不做过多讲解。该脚手架将webpack隐藏了起来,使用者不必去关注具体的webpack实现细节,而是操作相关的脚本即可。(当然,作为一名优秀的程序员,就算没有直接接触webpack,你也需要去官网看看create-react-app相关的文档)

此脚手架是基于create-react-app搭建了基于react+redux的脚手架,加上了基于koa2(也有express版本)实现的静态服务器,并且配置了pm2的自动化部署。
项目目录如下:

create-app-starter
├── README.md
├── node_modules
├── package.json
├── ecosystem.json  //pm2配置文件
├── .gitignore
├── public
│   └── favicon.ico
│   └── index.html
│   └── manifest.json
├── src
|   └── components #表现层组件
|   |   └── Loading
|   |       ├── index.js
|   |       └── index.scss
|   |   └── Dialog
|   └── containers #最外层的容器层,主要是provider包裹,传递store树
|   └── layout  #主要是整个容器样式进行初始化,在这可以添加nav,header,footer等无状态组件
|   └── routes   #路由层,主要通过路由来划分不同的组件
|   |   └── index.js  #路由的设置,推荐使用react-router
|   |   └── Home
|   |       ├── components # 容器型组件
|   |       ├── containers # 主要是使用connect 连接组件
|   |       ├── modules #定义action,并且执行reducers
|   |       └── index.js #结合webpack,根据路由做按需加载的操作 
|   └── store
|   |   ├── createStore.js  #创建store,添加一些middlewares
|   |   ├── location.js
|   |   └── reducers.js  //封装reducer,结合combineReducer  
|   ├── styles 
|   ├── registerServiceWorker.js  #create-react-app自带的servicework
|   └── index.js #入口文件
└── server #静态服务器

关于脚手架具体的说明,请各位去我的github上查看

下面开始介绍一下koa2搭建静态服务器。我们需要启动我们的客户端,静态服务器,无非就是读取静态资源,koa2的最大特点就是使用async/await来实现异步。

#安装
npm install koa

#安装koa2相关的中间件
npm install koa-static koa-morgan --save

代码如下:

app.js

const Koa = require('koa')
const morgan = require('koa-morgan')
const path = require('path');
const static = require('koa-static')
const fs = require('fs')

const app = new Koa();

// logger
app.use(morgan(':remote-addr - :remote-user [:date[clf]] ":method :url HTTP/:http-version" :status :res[content-length] :response-time ms'));

// static assets
app.use(static(path.resolve(__dirname, '..', 'build')));

//异步读取文件的形式
app.use(async (ctx,next) =>{
    ctx.type = 'html';
    ctx.body = await fs.createReadStream(path.resolve(__dirname, '..', 'build', 'index.html'));

})


module.exports = app;

index.js

'use strict';

const app = require('./app');

const PORT = process.env.PORT || 9000;

app.listen(PORT, () => {
  console.log(`App listening on port ${PORT}!`);
});

此时运行

node server

即可,当然也可以自定义端口

PORT=8000 node server

既然实现了静态服务器,当我们需要自己部署项目时,怎么去通过服务器部署自己的项目呢。

当然部署到服务器的方法有很多。仅仅node而言,pm2,forever等,甚至anywhere这样的,也能成功。或者粗暴的把整个项目cp到服务器上,再运行,都能访问。本文不讨论何种方法好。

当你的项目每次都要改动时,本地改完,push到仓库内,再从服务器pull下来,重新build,再采用如上的各种方法。这样无形之中就加大了时间成本,因而我的解决方法时采用pm2的自动化部署方法,来实现本地一键部署到服务器。

关于pm2的其他功能,本文不做相信处理,可以查看pm2官方文档

实现一键部署,我们需要做如下操作:

  1. 本地跟服务器都需要安装node,git,pm2
npm install pm2 -g
  1. 配置SSH

    1. 在Github上添加Deploy Keys
    ssh-keygen -t rsa
    cat ~/.ssh/id_rsa.pub
    

    然后复制内容,添加到Github上对应的项目仓库Settings下的Deploy keys中
    2.将 .pub 文件复制到服务器的 .ssh 目录, 并 cat

     # 将本地key添加到服务器的authorized_keys中
    id_dsa.pub >> ~/.ssh/authorized_keys
    
    1. 本地自动登录到服务器,避免每次都输入密码
    # name 是你的服务器用户名 server 是你服务器的地址
    
    ssh-copy-id name@serer
    
  2. 配置pm2

    1. 在服务器根目录下创建/www/website
    sudo mkdir /www
    cd /www
    sudo mkdir website
    #修改权限,先切换到www
    
    sudo chmod 777 website
    
    1. 下面是脚手架的ecosystem.json
    {
    "apps":{
        "name":"**",
        "script":"/server/index.js",
        "env":{
            "COMMON_VARIABLE":"true"
        },
        "env_production":{
            "NODE_ENV":"production"
        }
    },
    "deploy":{
        "production":{
            "user":"***", //服务器名称
            "host":["192.168.2.31"], //服务器ip
            "ref":"origin/master",
            "repo":"",
            "path":"/www/website/production", //项目目录
            "ssh_options":"StrictHostKeyChecking=no",
            "post-deploy":"npm install && npm run build && pm2 startOrRestart ecosystem.json --env production",
            "env":{
                "NODE_ENV":"production"
                }
            }
        }
    }
    
    1. 再服务器根目录编辑bash脚本,允许pm2脚本执行
    vi .bashrc
    

    注释掉

    #CASE
    # ...
    

    source .bashrc
    
    1. 执行
    pm2 deploy ecosystem.json production setup
    

    此时会在服务器 /www/website/production新建三个目录

    1. 发布
    pm2 deploy ecosystem.json production
    

    不出意外,即发布成功。

按照上述步骤操作,就可以实现利用pm2本地部署项目到服务器,这样就省掉了登入服务器取更新代码的步骤了。

当然,pm2还结合Nginx一同服务,具体的Nginx配置,请参考我另外一篇文章《学习Nginx配置》

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

推荐阅读更多精彩内容