Skip to main content
版本:v1.3

多环境部署

本章节会介绍,如何使用环境差异化配置(env-binding)为应用提供差异化配置和环境调度策略。

背景

在日常开发中会经常将应用部署计划(Application)部署到不同的环境。例如,在开发环境中对应用部署计划进行调试,在生产环境中部署应用部署计划对外提供服务。针对不同的环境,应用部署计划需要有差异化的配置。

如何使用

apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: example-app
namespace: demo
spec:
components:
- name: hello-world-server
type: webservice
properties:
image: oamdev/hello-world
port: 8000
traits:
- type: scaler
properties:
replicas: 1
- name: data-worker
type: worker
properties:
image: busybox
cmd:
- sleep
- '1000000'
policies:
- name: example-multi-env-policy
type: env-binding
properties:
envs:
- name: test
placement: # 选择要部署的目标命名空间
namespaceSelector:
name: test
selector: # 选择要使用的组件
components:
- data-worker

- name: staging
placement: # 选择要部署的目标集群
clusterSelector:
name: cluster-staging

- name: prod
placement: # 选择要部署的目标集群及命名空间
clusterSelector:
name: cluster-prod
namespaceSelector:
name: prod
patch: # 差异化配置该环境中的组件
components:
- name: hello-world-server
type: webservice
traits:
- type: scaler
properties:
replicas: 3

workflow:
steps:
# 部署 测试 环境
- name: deploy-test
type: deploy2env
properties:
policy: example-multi-env-policy
env: test

# 部署 预发 环境
- name: deploy-staging
type: deploy2env
properties:
policy: example-multi-env-policy
env: staging

# 人工确认
- name: manual-approval
type: suspend

# 部署 生产 环境
- name: deploy-prod
type: deploy2env
properties:
policy: example-multi-env-policy
env: prod

创建上述应用部署计划之前需要当前集群、预发集群 (cluster-staging) 中均有名为 demo 的命名空间,同时需要在当前集群中创建 test 命名空间、在生产 (cluster-prod) 集群中创建 prod 命名空间。你可以通过执行 kubectl create ns <namespace> 来创建它们。

kubectl apply -f app.yaml

应用部署计划创建之后,在 demo 命名空间下会创建一个配置化的应用部署计划。

$ kubectl get app -n demo
NAME COMPONENT TYPE PHASE HEALTHY STATUS AGE
example-app hello-world-server webservice running 25s

如果你想使用 env-binding 在多集群环境下创建应用部署计划,请参考 应用多集群部署

参数说明

环境差异化配置应用策略的所有配置项

名称描述类型是否必须默认值
envs环境配置env 数组

env 的属性

名称描述类型是否必须默认值
name环境名称string
patch对应用部署计划中的组件差异化配置patch 结构体
placement资源调度策略,选择将配置化的资源部署到指定的集群或命名空间上placement 结构体
selector为应用部署计划选择需要使用的组件,默认为空代表使用所有组件selector 结构体

patch 的属性

名称描述类型是否必须默认值
components需要差异化配置的组件component 数组

placement 的属性

名称描述类型是否必须默认值
clusterSelector集群选择器,通过名称筛选集群clusterSelector 结构体
namespaceSelector命名空间选择器,通过名称筛选集群namespaceSelector 结构体

selector 的属性

名称描述类型是否必须默认值
components需要使用的组件名称列表string 数组

clusterSelector 的属性

名称描述类型是否必须默认值
name集群名称string

namespaceSelector 的属性

NameDescTypeRequiredDefault Value
name命名空间名称string

你需要升级至 KubeVela v1.1.5+ 来启用 namespaceSelector.