教你使用docker部署淘宝rap2服务

什么是rap2

先来讲提及因,在上一个星期的分享会上,谈到先后端联调上,有同事提到了rap2,特地去了解了一下,以为使用这个东西来进行先后端的接口联调来真是太方便了,对比咱们以前公司内部开发的API Cloud来讲,我更偏向使用rap2javascript

RAP经过GUI工具帮助WEB工程师更高效的管理接口文档,同时经过分析接口结构自动生成Mock数据、校验真实接口的正确性,使接口文档成为开发流程中的强依赖。有告终构化的API数据,RAP能够作的更多,而咱们能够避免更多重复劳动。html

rap1

上面是摘自https://github.com/thx/RAP淘宝阿里妈妈对rap1的描述,看了图一会儿就能明白,后端制定API返回数据格式,前端经过接口地址在线mock,避免了先后端由于进度不一致而出现单方面等待的现象。前端

使用rap2

能够直接使用淘宝提供的在线服务来生成在线的接口地址,经过申请一个帐号后,便可在里面进行接口的编写、测试等等...这里再也不赘述。java

rap2-login

部署本身的rap2服务

由于rap2在github上面已经开源,并且也提供了部署方案,这里讲一下本身是如何使用docker来进行部署的。node

前提

  • 安装docker
  • 安装docker-compose

若是对docker不太熟悉,又想了解一下docker是什么的,不妨看看我以前的文章webpack

涉及到的两个开源仓库:nginx

  • rap2-delos: 后端数据API服务器,基于Koa + MySQL 戳这里
  • rap2-dolores: 前端静态资源,基于React 戳这里

或者使用本人的github仓库 Rynxiao/rap2-docker,已经包含了这两个仓库,并加入了配置。git

后端部署

在后端部署方面,在github上已经给出了使用docker的部署方面,所以,just follow就好。github

> mkdir rap2
> cd rap2
> git clone https://github.com/thx/rap2-delos.git
> cd rap2-delos
> docker-compose up -d

rap2-delos

运行成功后,须要手动初始化数据库,咱们进入对象的容器来操做:web

> docker exec -it rap2-delos sh
> node scripts/init
> exit

从新启动服务:

> docker-compose down
> docker-compose up -d

compose

能够看到暴露出来的端口是38080,咱们使用curl命令来测试一下是否成功,若是放回Hello RAP!,就说明后端已经部署好了。

> curl localhost:38080

hello-rap

前端部署

前端因为没有提供对应的docker部署方法,所以只有我本身来尝试部署了。前端使用的是node进行webpack打包,所以须要一个node的环境,因此我在制做容器的时候须要拉去一个node镜像。

由于部署前端以前没有看后端的部署,因此我前端拉取了一个比较新的版本[10.1.0],若是想和后端公用一个node镜像,可使用这个node:8.11.1-alpine镜像。

经过npm run build以后,生成的build文件夹中的只是静态资源文件,所以我还须要起一个服务器,这里我经过全局安装http-server来启动一个服务。

下面是具体的过程:

1. git仓库拉取

> cd rap2
> git clone https://github.com/thx/rap2-dolores.git
> cd rap2-dolores

2. 建立一个Dockerfile来构建一个新的node版本镜像

> touch Dockerfile
> vim Dockerfile

Dockerfile中的内容为:

# 拉取10.1.0版本的node镜像
FROM node:10.1.0

# 维护人
MAINTAINER ryn

# 建立工做目录
RUN mkdir -p /home/rap2-dolores
WORKDIR /home/rap2-dolores

# 将代码拷贝至工做目录
COPY . /home/rap2-dolores

# 全局安装http-server服务器
RUN npm install -g http-server

# 全局安装node-sass(必定要带--unsafe-perm,不然会报错)
RUN npm install --unsafe-perm -g node-sass

# 安装依赖
RUN npm install

# 打包
RUN npm run build

3. 使用docker-compose来启动服务

> touch docker-compose.yml
> vim docker-compose.yml

docker-compose.yml中的内容为:

version: '2.2'

services:
  delores:
    # 容器名称
    container_name: rap2-dolores
    
    # 经过Dockerfile来构建本地镜像
    build: .
    
    # 经过images来构建,这里的地址暂不适用,由于src/config中的配置须要根据本身的服务器来动态构建
    # image rynxiao/rap2-dolores-nodejs
    
    # 指定工做目录
    working_dir: /home/rap2-dolores
    
    # 指定生产环境
    environment:
      - NODE_ENV=production
      
    # 启动http-server,并映射端口到容器内部8081上
    command: /bin/sh -c 'http-server ./build -s -p 8081'
    privileged: true
    
    # expose port 38081
    ports:
      - "38081:8081"

更改src/config/config.prod.js中的配置,将接口请求地址指向你的后端服务器,如下是个人配置,各位按需更改。

module.exports = {
  serve: 'http://xxx.xxx.xxx.xx:38080',
  keys: ['some secret hurr'],
  session: {
    key: 'koa:sess'
  }
}

注意上面的xxx.xxx.xxx.xxx是你公网的ip地址,若是你经过端口映射作了二级域名的配置,也能够去掉端口号,直接写你的二级域名就能够了,好比你的二级域名为:http://rap2.xxx.com,那么serve就能够配置为http://rap2.xxx.com

启动服务

> docker-compose up -d

这一步会执行镜像的构建,使用docker ps能够查看最新的构建镜像,使用docker-compose ps能够查看运行的容器

rap2-dolores-ps

至此,咱们就可使用http://{youdomain}:38081来访问rap2了。

rap2-login

nginx作二级域名转换

你可能但愿上使用http://rap2.{youdomain}.com来访问刚刚咱们建立的rap2服务,这里我使用nginx作地址转换,步骤以下:

在腾讯云/万网中加一条A类记录

我使用的是腾讯云,阿里云的添加方法也大体相似,这里请你们自行谷歌。

rap2-record

在nginx中增长一个server配置

> cd /usr/local/nginx-1.13.9/conf
> mkdir sites-enabled
> cd sites-enabled
> vim rap2.{youdomain}.com.conf

rap2.{youdomain}.com.conf中的内容以下:

server {
    listen 80;
    server_name rap2.{youdomain}.cn;
    access_log  logs/rap2-site.log;

    location / {
      proxy_redirect off;
      proxy_set_header Host $host;
      proxy_set_header X-Real-Ip $remote_addr;
      proxy_set_header X-Forwarded-For $remote_addr;
      proxy_pass http://127.0.0.1:38081/;
    }
}

其实就是作了一个端口转换。接下来在nginx.conf中进行引入

# nginx.conf http模块
include /usr/local/nginx-1.13.9/conf/sites-enabled/*.conf;

# 重启nginx
nginx -s reload

而后咱们就可使用rap2.{youdomain}.com来访问rap2服务了

注:{youdomain}替换为本身的域名

小结

算是对以前学习的docker进行练手,经过实践仍是学到了一些本身不太熟悉的领域的一些知识,记录共勉之。

相关文章
相关标签/搜索