kubernetes 自定义资源定义必填字段

sac*_*boy 3 kubernetes kubernetes-custom-resources

我正在尝试编写 kubernetes crd 验证架构。我有一个结构数组 (vc),这些结构中的一个字段是必需的(name字段)。

我尝试查看各种示例,但当name不存在时它不会生成错误。有什么建议有什么问题吗?

vc:
  type: array
  items:
    type: object
    properties:
      name:
        type: string
      address:
        type: string
    required:
    - name
Run Code Online (Sandbox Code Playgroud)

Nik*_*ath 5

如果您使用的是 v1.8,则需要启用CustomResourceValidation功能门才能使用验证功能。这可以通过在 kube-apiserver 上使用以下标志来完成:

--feature-gates=CustomResourceValidation=true
Run Code Online (Sandbox Code Playgroud)

这是一个它的工作示例(我在 v1.12 上测试了这个,但这也应该适用于早期版本):

CRD:

apiVersion: apiextensions.k8s.io/v1beta1
kind: CustomResourceDefinition
metadata:
  name: foos.stable.example.com
spec:
  group: stable.example.com
  versions:
    - name: v1
      served: true
      storage: true
  version: v1
  scope: Namespaced
  names:
    plural: foos
    singular: foo
    kind: Foo
  validation:
    openAPIV3Schema:
      properties:
        spec:
          properties:
            vc:
              type: array
              items:
                type: object
                properties:
                  name:
                    type: string
                  address:
                    type: string
                required:
                - name
Run Code Online (Sandbox Code Playgroud)

自定义资源:

apiVersion: "stable.example.com/v1"
kind: Foo
metadata:
  name: new-foo
spec:
  vc:
  - address: "bar"
Run Code Online (Sandbox Code Playgroud)
  1. 创建 CRD。

kubectl create -f crd.yaml customresourcedefinition.apiextensions.k8s.io/foos.stable.example.com created

  1. 获取 CRD 并检查输出中是否存在验证字段。如果没有,您可能没有打开功能门。

kubectl get crd foos.stable.example.com -oyaml

  1. 尝试创建自定义资源。这应该会失败:

kubectl create -f cr-validation.yaml

The Foo "new-foo" is invalid: []: Invalid value: map[string]interface {}{"metadata":map[string]interface {}{"creationTimestamp":"2018-11-18T19:45:23Z", "generation":1, "uid":"7d7f8f0b-eb6a-11e8-b861-54e1ad9de0be", "name":"new-foo", "namespace":"default"}, "spec":map[string]interface {}{"vc":[]interface {}{map[string]interface {}{"address":"bar"}}}, "apiVersion":"stable.example.com/v1", "kind":"Foo"}: validation failure list: spec.vc.name in body is required