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

什么是rap2

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

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

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

使用rap2

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

部署自己的rap2服务

因为rap2在github上面已经开源,而且也提供了部署方案,这里讲一下自己是如何使用docker来进行部署的。

前提

  • 安装docker
  • 安装docker-compose

如果对docker不太熟悉,又想了解一下docker是什么的,不妨看看我之前的文章

涉及到的两个开源仓库:

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

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

后端部署

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

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

运行成功后,需要手动初始化数据库,我们进入对象的容器来操作:

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

重新启动服务:

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

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

> curl localhost:38080

前端部署

前端由于没有提供对应的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可以查看运行的容器

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

nginx做二级域名转换

你可能希望上使用http://rap2.{youdomain}.com来访问刚刚我们创建的rap2服务,这里我使用nginx做地址转换,步骤如下:

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

我使用的是腾讯云,阿里云的添加方法也大致类似,这里请大家自行谷歌。

在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进行练手,通过实践还是学到了一些自己不太熟悉的领域的一些知识,记录共勉之。

原文地址:https://www.cnblogs.com/rynxiao/p/9080179.html

时间: 2024-10-28 13:15:16

教你使用docker部署淘宝rap2服务的相关文章

教你一种免费领取淘宝优惠券的方法

大家好,今天教大家一种免费领取淘宝优惠券的方法1.安卓和苹果手机到各大APP市场下载一下[花生日记],注意图标是有官方正版字样2.手机注册一下(免费注册),邀请码:RIS8SMO3.登录淘宝,找到你要购买的宝贝,复制一下[宝贝标题]4.打开花生日记,即可以自动搜索这个宝贝的优惠券,点击领取(如果没有优惠券就是卖家没有优惠,85%的商品都有优惠券)5.领取后,会自动跳回淘宝完成支付即可:6.每次可以节省5元--几百元不等(看订单金额大小) 原文地址:http://blog.51cto.com/11

类比 RocketMq 和 淘宝消息服务:

rocketMq建立监听: 一个groupId下通常会挂载多个consumer实例. 集群订阅方式 (默认):一个监听到之后,另一个consumer实例就不会再监听到(不管在不在一个服务器上). 由于默认集群订阅方式,只能有一个监听到,所以,本地测试和服务器上topic不能一致,否则会影响服务器上监听不到消息.而topic 的不一致导致本地测试和服务端测试,groupID也不一致,但多台服务器上需要多个groupId, 淘宝消息服务: 通过SDK接受消息,Java接口使用说明: public i

手把手教你用Docker部署一个MongoDB集群

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中最像关系数据库的.支持类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引.本文介绍了如何使用Docker搭建MongoDB集群. 本文我会向大家介绍如何使用Docker部署一个MongoDB集群,具体如下: 2.6.5版本的MongoDB 有3个节点的副本集(Replica set) 身份验证 持久化数据到本地文件系统 首先要准备三个运行的Docker服务器,这意味着你

docker部署PiggyMetrics分布式微服务

在上一篇文章里http://www.cnblogs.com/lyhero11/p/8686058.html, 讲解了如何在windows10下安装docker社区版. 那如何利用docker落地一个分布式微服务架构的系统呢? github上有一个不错的开源项目PiggyMetrics,通过这个可以学习用docker和spring cloud做分布式微服务架构. 原项目地址:https://github.com/sqshq/PiggyMetrics 国内有个网友把里边应用的mongodb数据库示例

模仿淘宝页面碰到的问题

上周四 周五这个样子差不多把淘宝页面大部分完工了.1.24号开始的,2.5-2.6这样结束的,应该是说差不多结束.我写页面一般是看的360浏览器,后来写完之后去看火狐和IE,还是蛮多问题的. 首先就是字体.font-size:10px:在360下看着蛮正常的,在火狐和IE下看着好小. 我在CSS文件的最开始设置了通用样式,后来写着写着我都忘了自己已经定义了字体了. 还有边框的问题,在360  火狐下看着蛮正常,结果在IE下都溢出了.我看了下在360,火狐下的行高35px,在IE8下变成了30px

电商客户端竞品分析-手机淘宝、京东、唯品会、聚美优品

市场状况 艾瑞最新统计数据显示,2013年移动网购整体交易规模1676.4亿元,同比增幅高达165.4%,而同期PC端网购规模将近16000多亿元,同比增速35.7%.预计2017年市场规模将近万亿,增速39.4%. 图1 2011-2017年中国移动购物市场交易规模 2013年中国移动网购渗透率9.1%,同比去年增长超过四个百分点.预计到2017年移动购物渗透率达到24.1%. 图2 2011-2017年中国网购交易额PC端和移动端占比 2013年移动网购企业份额中,手机淘宝占比76.1%,京

淘宝静态页面

1 <!DOCTYPE html> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 5 <title></title> 6 <link href="css/

C#编写Windows服务程序 (服务端),client使用 消息队列 实现淘宝 订单全链路效果

需求: 针对 淘宝提出的 订单全链路 产品接入 .http://open.taobao.com/doc/detail.htm?id=102423&qq-pf-to=pcqq.group oms(订单管理系统) 实现  , 完毕后 效果:在千牛工作台 --订单全链路  可看到效果例如以下图   -------------------------------------------------------------------------------------------------------

C#编写Windows服务程序 (服务端),客户端使用 消息队列 实现淘宝 订单全链路效果

需求: 针对 淘宝提出的 订单全链路 产品接入 .http://open.taobao.com/doc/detail.htm?id=102423&qq-pf-to=pcqq.group oms(订单管理系统) 实现  , 完成后 效果:在千牛工作台 --订单全链路  可看到效果如下图   ---------------------------------------------------------------------------------------------------------