5

我有一组在一个环境中工作的 kubernetes 配置文件。我希望部署到另一个环境中,我需要在所有配置中添加一个 imagePullSecrets 条目Deployment

我可以:

regred-1.yaml:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: deployment-1
spec:
  template:
    spec:
      imagePullSecrets:
      - name: regcred

kustomization.yaml:

bases:
  - ../base

patchesStrategicMerge:
  - regcred-1.yaml

那只会打补丁deployment-1

有没有办法将补丁应用于所有部署?

4

3 回答 3

5

您可以使用patches字段而不是patchesStrategicMerge为了修补多个资源。

基于这个演示示例,您可以通过指定补丁和目标选择器来做到这一点:

patches:
- path: <PatchFile>   target:
    group: <Group>
    version: <Version>
    kind: <Kind>
    name: <Name>
    namespace: <Namespace>
    labelSelector: <LabelSelector>
    annotationSelector: <AnnotationSelector>

在这种情况下,您kustomization.yaml应该如下所示:

bases:
  - ../base

patches:
- path: regcred-1.yaml
 target:
   kind: Deployment

让我知道这是否解决了您的问题。

于 2019-12-09T15:28:37.290 回答
4

像这样的东西似乎可以附加一个imagePullSecret

patches:
    -   target:
            kind: Deployment
        patch: |-
            - op: add
              path: /spec/template/spec/imagePullSecrets/-
              value:
                name: regcred
    -   target:
            kind: CronJob
        patch: |-
            - op: replace
              path: /spec/jobTemplate/spec/template/spec/imagePullSecrets
              value:
                - name: regcred

或者更简单地说,您可以只运行一次:

kubectl patch serviceaccount default -p '{"imagePullSecrets": [{"name": "regcred"}]}'
于 2020-06-07T22:49:19.763 回答
0

使用内联补丁

kind: Kustomization
apiVersion: kustomize.config.k8s.io/v1beta1
resources:
  - ../../base
patches:
  - target:
      kind: Deployment
    patch: |-
      - op: add
        path: /spec/template/spec/imagePullSecrets
        value: [{ name: image-pull-secret }]

参考:一次修补多个资源。

于 2021-07-29T02:48:37.530 回答