组件编排
在 KubeVela 中,可以在组件中通过 来指定组件间的依赖关系。
如:A 组件依赖 B 组件,需要在 B 组件完成部署后再进行部署:
...
components:
- name: A
type: helm
dependsOn:
- B
- name: B
type: helm
在这种情况下,KubeVela 会先部署 B,当 B 组件的状态可用时,再部署 A 组件。
假设我们需要在本地启动一个 MySQL 集群,那么我们需要:
- 部署一个 Secret 作为 MySQL 的密码。
- 部署 MySQL controller。
- 部署 MySQL 集群。
apiVersion: core.oam.dev/v1beta1
kind: Application
metadata:
name: mysql
namespace: default
spec:
components:
- name: mysql-secret
type: raw
properties:
apiVersion: v1
kind: Secret
metadata:
name: mysql-secret
type: kubernetes.io/opaque
stringData:
ROOT_PASSWORD: test
- name: mysql-controller
properties:
repoType: helm
url: https://presslabs.github.io/charts
chart: mysql-operator
version: "0.4.0"
- name: mysql-cluster
type: raw
dependsOn:
- mysql-controller
- mysql-secret
properties:
apiVersion: mysql.presslabs.org/v1alpha1
metadata:
name: mysql-cluster
spec:
replicas: 1
secretName: mysql-secret
期望结果
查看集群中的应用:
一开始,由于 mysql-controller 尚未部署成功,三个组件状态均为 runningWorkflow。
$ vela ls
APP COMPONENT TYPE TRAITS PHASE HEALTHY STATUS CREATED-TIME
mysql mysql-secret raw running healthy 2021-10-14 12:09:55 +0800 CST
├─ mysql-controller helm running healthy 2021-10-14 12:09:55 +0800 CST
└─ mysql-cluster raw running 2021-10-14 12:09:55 +0800 CST
可以看到,所有组件都已成功运行.其中 mysql-cluster
组件的部署依赖于 mysql-controller
和 mysql-secret
部署状态达到 healthy
。
dependsOn
会根据组件是否healthy
来确定状态,若已healthy
,则表示该组件已成功运行,可以部署下一个组件。 如果你向自定义组件的健康状态,请查看
参数传递
除了显示指定依赖关系以外,还可以在组件中通过 outputs 和 inputs 来指定要传输的数据。
valueFrom
有以下几种写法:
- 通过指定 value 来指定值,如:
valueFrom: output.metadata.name
。注意,output
为固定内置字段,指向组件中被部署在集群里的资源。 - 使用 CUE 表达式。如,用
+
来连接值和字符串:valueFrom: output.metadata.name + "testString"
。你也可以引入 CUE 的内置包:
valueFrom: |
import "strings"
strings.Join(["1","2"], ",")
Inputs
inputs 由 from
和 parameterKey
组成。from
声明了这个 input 从哪个 output 中取值,parameterKey
为一个表达式,将会把 input 取得的值赋给对应的字段。
如:
- 指定 inputs:
- 经过渲染后,该组件的
properties.values.externalDatabase.host
字段中会被赋上值,效果如下所示:
...
- name: wordpress
type: helm
properties:
values:
host: <input value>
假设我们希望在本地启动一个 WordPress,而这个 Wordpress 的数据存放在一个 MySQL 数据库中,我们需要将这个 MySQL 的地址传递给 WordPress。
部署如下应用部署计划:
kind: Application
metadata:
name: wordpress-with-mysql
namespace: default
spec:
components:
- name: mysql
type: helm
outputs:
# 将 service 地址作为 output
- name: mysql-svc
valueFrom: output.metadata.name + ".default.svc.cluster.local"
properties:
repoType: helm
url: https://charts.bitnami.com/bitnami
chart: mysql
version: "8.8.2"
values:
auth:
rootPassword: mypassword
- name: wordpress
type: helm
inputs:
# 将 mysql 的 service 地址赋值到 host 中
- from: mysql-svc
parameterKey: properties.values.externalDatabase.host
properties:
repoType: helm
url: https://charts.bitnami.com/bitnami
chart: wordpress
version: "12.0.3"
values:
mariadb:
enabled: false
externalDatabase:
user: root
password: mypassword
port: 3306
期望结果
WordPress 已被成功部署,且与 MySQL 正常连接。