/masker-json-server

Web应用:基于masker-rest实现的简易json server(供前端开发使用,用来mock后端接口及报文,本地启动后访问http://127.0.0.1:port 即可访问管理服务)

Primary LanguageJavaApache License 2.0Apache-2.0

masker-json-server

Web应用:基于 masker-rest 实现的简易json server(供前端开发使用,用来mock后端接口及报文)

  • 主要功能

    • 配置启动http server,可在运行时动态启停http服务(监听不同端口)

    • 为http server动态配置响应json格式数据的接口

    • 支持根据接口参数(method、headers、params、body)来通过aviator表达式匹配返回不同json格式数据(例如:分页查询接口,根据页码返回不同页数据)

      • method:http method(例如:get、post、put、delete等)

      • headers:请求头(从http请求头获取请求header)

        • 注意:headers参数对象下的元素为key-value键值对,value值类型为字符串
      • params:请求接口URL参数

        • 注意:params参数对象下的元素为key-value键值对,value值类型为字符串
      • body:请求body对象(http请求body,格式:json)

        • 注意:body对象下的元素为key-value键值对,value值类型为json数据的各类值类型
      • 路由表达式的结果应为布尔值,含义为路由表达式通过则匹配返回相应接口报文

      • 路由表达式样例:method == "post" && headers.key1 == "value1" && params.key2 == "value2" && body.key3 == "value3" && body.key5 == 5

    • 支持配置接口的代理Server(保证接口服务地址不变的情况下可一键切换mock报文或真实服务地址)

  • 技术组件

    • 使用 layui 实现前端控制台

    • 使用 masker-rest 实现后端接口服务,动态启停http服务也依赖于此组件

    • 使用 sdk-sqlite3 实现存储,启动时初始化表结构到本地SQLite3数据库,无需额外部署数据库

  • 运行配置

    • 运行环境:JDK17+

    • 启动参数

    # 指定服务端口(不指定则默认8080)
    -p 18080
    --port 18080
    # 指定工作目录(不指定则默认当前程序运行目录)
    -w /app/json-server
    --workspace /app/json-server
    # 示例启动命令
    java -jar masker-json-server.jar -p 18080 -w /app/json-server
    
    • JVM参数(参考)
    -Xms64m
    -Xmx64m
    -XX:MetaspaceSize=64M
    -XX:MaxMetaspaceSize=64M
    -XX:+DisableAttachMechanism
    
  • Docker部署文档

    • 构建可执行jar包(输出服务包名:json-server.jar)

    • Docker宿主机创建目录

    # 构建&日志&数据存储目录
    mkdir -p /app/docker/json-server/{build,logs,workspace}
    
    • 拷贝 Dockerfile 及可执行jar包,上传至安装Docker的主机,存放目录:/app/docker/json-server/build

      • 备注:从容器访问宿主机,使用默认桥接模式访问主机(ip addr show docker0,可查看主机上Docker IP,默认:172.17.0.1)
    • 执行镜像构建命令:docker build -t json-server:${version} ./

      • 镜像名称:json-server

      • 镜像版本:${version}

      • Dockerfile文件名称:参数-f Dockerfile,若不指定"-f"参数默认找"Dockerfile"

      • Dockerfile文件存放目录:./

      • 镜像构建完成后可查看镜像:docker images

    • 至此,Docker镜像已构建完成,以下为部署配置+启动步骤

    • 启动json-server容器命令

    docker run -itd \
    -v /app/docker/json-server/logs:/app/json-server/logs \
    -v /app/docker/json-server/workspace:/app/json-server/workspace \
    --net=host \
    --restart=always \
    --name json-server \
    json-server:${version}
    
    # json-server服务运行时涉及http服务的动态启停,在运行时需容器暴露的服务端口会动态变化
    # 因此不使用"-p "参数来进行端口映射,而是使用"--net=host"来与宿主机共享网络
    # Dockerfile中启动入口指定了json-server的服务端口18080