dice.yml

    完整例子位于文档尾部。

    dice.yml 文件全局结构定义有 5 项全局配置,分别如下:

    version 的值目前定义为 2.0,只需要配置为: 即可。

    values

    values 用以设置不同环境中的变量,以便在一份 dice.yml 中维护各个环境下的配置。它的格式为:

    1. values:
    2. workspace:
    3. key: value

    引用 values 中的变量的方式为 ${key: default_value}

    示例:

    1. values:
    2. development:
    3. cpu: 0.5
    4. test:
    5. cpu: 0.5
    6. staging: {}
    7. production:
    8. cpu: 2
    9. services:
    10. serviceA:
    11. resources:
    12. cpu: ${cpu:1}

    以上示例中,用 “cpu” 配置服务在不同环境下所需的 cpu 值。 services.serviceA.resources.cpu 的值 ${cpu:1} 引用了这个变量,那么部署到 development 和 test 环境时,cpu 的值为 0.5; 部署到 staging 环境时,cpu 的值为默认值 1;部署到 production 环境时,cpu 的值为 2。

    envs

    envs 定义环境变量,envs 分全局定义和 service 内定义两种,此处展示的全局结构为全局定义,通过 envs 配置全局定义的环境变量将被应用到所有的 services 里。全局环境变量和 service 内环境变量重复的时候,以 service 内环境变量为准,也就是 service 内环境变量可以覆盖全局环境变量。

    例子:

    1. envs:
    2. Debug: true
    3. Host: erda.terminus.io
    4. Key: value

    services 定义具体的一组 service 集合,为整个应用需要被编排部署的所有服务,具体的内容包含微服务名、resources、deployments、 ports、 envs。

    例子:

    1. services:
    2. # serviceA 是自定义的服务 A 的名字,不是 dice.yml 的配置项。
    3. serviceA:
    4. resources:
    5. cpu: 0.1
    6. mem: 256
    7. deployments:
    8. replicas: 2
    9. labels:
    10. GROUP: erda
    11. ports:
    12. - port: 9093
    13. envs:
    14. ADDON_PLATFORM_ADDR: addon
    15. # serviceB 是自定义的服务 B 的名字,不是 dice.yml 的配置项。
    16. serviceB:
    17. ...

    addons

    addons 是指在应用内能够被所有微服务依赖使用的基础服务,也可以称为微服务的插件服务。 addons 包括但不限于 MySQL、Kafka、ElasticSearch、Redis 等基础软件服务,用户自己研发的微服务也可以沉淀成 addon ,按照定义规则发布的到服务市场,详情请参考 介绍。

    例子:

    1. addons:
    2. # mysql 是自定义的 Add-On 实例名字
    3. mysql:
    4. plan: mysql:basic
    5. version: 5.7.23
    6. # create_dbs 是在MySQL实例上需要创建一个或者多个逻辑库名称
    7. create_dbs: blog,user
    8. # zk 也是一个自定义的 AddOn 实例名字
    9. zk:
    10. plan: zookeeper:basic

    dice.yml 内置了一套配置项用来定义整个微服务应用,它们是编写 dice.yml 的基础。 配置项分为全局配置项、service 配置项、addon 配置项。

    全局配置项

    • version
    • values
    • envs
    • services
    • addons

    上文已详细介绍。

    values 配置项即 development, test, staging 以及 production 四个 workspace 名称,分别表示开发环境,测试环境,预发环境和生产环境。

    service 配置项

    service 配置项顾名思义是对微服务部署具体内容配置。

    image

    例子:

    1. image: nginx:latest

    cmd

    例子:

    ports

    配置 service 监听的端口,可以有多个, 对于需要被暴露给外部用户访问的端口, expose 设置为 true,当不指定 expose 时,如果需要暴露外部使用,默认取第一个端口

    例子:

    1. ports:
    2. - port: 1234
    3. expose: false
    4. - port: 4321
    5. expose: true

    envs

    配置 service 的环境变量,和全局的 envs 定义的环境变量重复的时候会覆盖全局配置,优先使用 service 内配置

    例子:

    1. envs:
    2. Debug: false
    3. Key: value

    hosts

    例子:

    1. hosts:
    2. - 127.0.0.1 www.terminus.io
    3. - 127.0.0.2 dice.terminus.io

    resources

    配置 service 所需要的资源,资源包括 cpu、内存和磁盘,resources 包含如下子配置项:

    cpu: 配置 cpu 核数,可以是小数,不足一个核;必配选项,没有默认值。

    mem: 配置内存数,单位是 M;必配选项

    disk:配置磁盘大小数,单位是 M

    network: 容器网络配置, 可选配置, 可配置为 overlayhost, 默认为 overlay

    例子:

    1. resources:
    2. cpu: 1
    3. mem: 256
    4. disk: 1024
    5. network:
    6. mode: overlay

    capabilities

    配置 service 的 linux capabilities, man 7 capabilities 查看全部可用的 linux capabilities。

    cap_add: 添加 capability

    cap_drop: 删除 capability

    例子:

    1. cap_add:
    2. - ALL
    3. cap_drop:
    4. - NET_ADMIN
    5. - SYS_ADMIN

    deployments

    配置 service 的部署策略,目前支持配置实例数、labels 等,所以有如下配置项:

    mode: 部署模式可以指定为 globalreplicated 两种,global 表示每个集群节点部署一个容器实例,replicated 表示部署指定数量的容器实例,与 replicas 选项配合使用,默认为:replicated

    例子1:

    1. deployments:
    2. mode: replicated
    3. replicas: 2

    例子2:

    depends_on

    例子:

    1. # 例子表示此服务依赖于 serviceB 和 serviceC 两个服务
    2. depends_on:
    3. - serviceB
    4. - serviceC

    volumes

    volumes 为容器目录提供持久化存储功能,可以同时指定多个配置。 storage: 当前只支持 nfs。 path: 指定容器内部挂载路径,需要使用绝对路径。

    例子:

    1. volumes:
    2. - storage: nfs
    3. path: /container/data

    health_check

    health_check 配置 service 的健康检查机制,健康检查有两种接口供使用,分别是 http 和 command,配置 health_check 的时候只能二选一,不能同时使用 http 和 command。

    http 健康检查就是向一个 http 接口发送 GET 请求,通过响应的状态是否为 200 来判断服务的健康情况。

    例子和说明:

    1. health_check:
    2. http:
    3. # port 配置健康检查 http get 请求的端口,此端口应该是 ports 配置中的一个
    4. port: 8080
    5. # path 配置健康检查 http get 的 URI 路径
    6. path: /health
    7. # duration 设定健康检查需要持续的检查的时间,单位是秒;这个时间值应该设置为比服务启动需要的时间更长一点
    8. duration: 120

    command 健康检查是运行一个指定的命令,通过命令执行的退出码是否为 0 来判断服务的健康情况。

    例子和说明:

    1. health_check:
    2. exec:
    3. # cmd 配置要运行的命令,此处的 curl 只是一个例子,你可以写任何想要的命令
    4. cmd: curl http://127.0.0.1:8080/health
    5. # duration 同 http 健康检查
    6. duration: 120

    addon 配置项

    addon 配置项是一个具体的 addon 对象描述,具体包含了 addon 的类型、规格以及附加参数等信息。

    例子:

    1. addons:
    2. mysql: # mysql 是自定义的 Add-on 实例名字
    3. plan: mysql:basic # plan:表示规格
    4. options: # options:附加参数,如版本
    5. version: 5.7.23
    6. # create_dbs 是在MySQL实例上需要创建一个或者多个逻辑库名称
    7. create_dbs: blog,user

    名称

    平台通过名称来做共享策略,用户自定义名称后,在相同项目环境下,通过该名称可以自动共享Add-on。需要注意的是,在平台的开发、测试两个环境中,该名称会被自动忽略,直接修改为Add-on本身的名称。

    plan

    plan 为描述 addon 的类型和规范,格式如下:

    plan: {addon类型}:{规格}

    可选规格:根据具体的 addon 决定,一般有( basic、professional、ultimate )

    例子:

    1. # 这是一个 basic 规格的 mysql addon
    2. plan: mysql:basic

    options

    1. version: 2.0
    2. # values 并不是必须的, 但如果你要为某些参数在不同环境下配置不同的值, 它将很有用
    3. values:
    4. development:
    5. cpu: 0.5
    6. test:
    7. staging: {}
    8. production:
    9. cpu: 2
    10. mem: 1024
    11. # 全局环境并不是必须的
    12. envs:
    13. DEBUG: true
    14. TERMINUS_TRACE_ENABLE: false
    15. services:
    16. # showcase-front 是一个 service 的名字,你需要根据自己的服务在这里填写正确的名字
    17. showcase-front:
    18. image: nginx:latest
    19. cmd: echo hello && npm run start
    20. ports:
    21. - port: 8080
    22. expose: true
    23. # service 内的 envs 用于定义服务私有的环境变量,可以覆盖全局环境变量中的定义。
    24. envs:
    25. TERMINUS_TRACE_ENABLE: false
    26. TERMINUS_APP_NAME: showcase-front-app
    27. hosts:
    28. - 127.0.0.1 www.terminus.io
    29. resources:
    30. cpu: ${cpu:1} # 在开发环境和测试环境 cpu=0.5; 在预发环境 cpu=1; 在生产环境, cpu=2
    31. mem: ${mem:256} # 在生产环境, mem=1.24; 在其他环境, mem=256, 即默认值
    32. disk: 100
    33. network:
    34. mode: container
    35. deployments:
    36. # replicas 不能小于 1,replicas 定义了服务需要被部署几个容器实例。
    37. replicas: 2
    38. depends_on:
    39. - blog-servic
    40. volumes:
    41. - storage: nfs
    42. path: /container/data
    43. health_check:
    44. http:
    45. port: 8080
    46. path: /health
    47. duration: 120
    48. # blog-service 示范了最简洁的服务配置,也就是只配置了最必须的配置项。
    49. blog-service:
    50. image: nginx:latest
    51. resources:
    52. cpu: 0.2
    53. mem: 256
    54. disk: 100
    55. deployments:
    56. replicas: 3
    57. addons:
    58. mysql:
    59. plan: mysql:basic
    60. as: MYSQL
    61. options:
    62. version: 5.7.23
    63. create_dbs: blog,blog2
    64. zk:
    65. plan: zookeeper:professional