登录
首页 >  Golang >  Go问答

在地图上迭代 Helm 模板

来源:stackoverflow

时间:2024-02-20 15:45:23 301浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《在地图上迭代 Helm 模板》,聊聊,我们一起来看看吧!

问题内容

我正在尝试创建一个 helm 模板来创建 networkpolicy,但在迭代地图时遇到一些问题。 这是我的值文件中的内容(示例):

extrapolicies:
  - name: dashboard
    policytype:
      - ingress
      - egress
    ingress:
      from:
        - ipblock:
            cidr: 172.17.0.0/16
            except:
              - 172.17.1.0/24
        - namespaceselector:
            matchlabels:
              project: myproject
      ports:
        - protocol: tcp
          port: 6379
        - protocol: tcp
          port: 8080
    egress:
      to:
        - ipblock:
            cidr: 10.0.0.0/24
      ports:
        - protocol: tcp
          port: 5978
  - name: dashurboard-integ
    policytype:
      - ingress
      - egress
    ingress:
      from:
        - ipblock:
            cidr: 172.17.0.0/16
            except:
              - 172.17.1.0/24
        - namespaceselector:
            matchlabels:
              project: myproject
      ports:
        - protocol: tcp
          port: 6379
        - protocol: tcp
          port: 8080
    egress:
      to:
        - ipblock:
            cidr: 10.0.0.0/24
      ports:
        - protocol: tcp
          port: 5978

这就是我的模板中目前的内容:

{{- if .Values.extraPolicies -}}
{{- $fullName := include "network-policies.fullname" . -}}
{{- $namespace := .Values.deployNamespace }}
{{- range $i, $policy := .Values.extraPolicies }}
---
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
  name: {{ $policy.name }}
  namespace: {{ $namespace }}
spec:
  policyTypes:
  {{- range $i2, $type := $policy.policyType }}
  - {{ $type -}}
  {{- end }}
  ingress:
  - from: |-
      {{- range $i3, $ingress := $policy.ingress }}
      - {{ $ingress }}
      {{- end }}
  egress:
  - to:
    - ipBlock:
        cidr: 10.0.0.0/24
    ports:
    - protocol: TCP
      port: 5978
  {{- end }}
{{- end }}

带有 |- 的“from”块表明我正在处理地图,但我不知道如何迭代它们并获得像values.yml中那样格式化的输出。

非常感谢任何帮助。


解决方案


发现我从一开始就采用了错误的方法来构建数据。它可能不是最好的解决方案,我欢迎任何和所有改进和/或建议,但我不再被阻止。

我让它可以满足我的需要。

值.yml

extrapolicies:
- name: dashboard
  policytype:
    - ingress
  ingress:
    - name: podselector
      settings:
        all: {}
    - name: ipblock
      settings:
        cidr: "172.17.0.0/16"
    - name: namespaceselector
      settings:
        matchlabels:
          project: test
          namespace: mynamespace
  ingressports:
    - protocol: tcp
      port: 6379
    - protocol: tcp
      port: 8080
- name: dasboard-integ
  policytype:
    - ingress
  ingress:
    - name: podselector
      settings:
        all: {}
    - name: ipblock
      settings:
        cidr: "172.17.0.0/16"
  ingressports:
    - protocol: tcp
      port: 3000
    - protocol: tcp
      port: 8000
    - protocol: tcp
      port: 443
    - protocol: tcp
      port: 80

和模板:

{{- if .values.extrapolicies -}}
{{- $fullname := include "network-policies.fullname" . -}}
{{- $namespace := .values.deploynamespace }}
{{- range .values.extrapolicies }}
---
apiversion: networking.k8s.io/v1
kind: networkpolicy
metadata:
  name: {{ .name }}
  namespace: {{ $namespace }}
spec:
  policytypes:
  {{- range $i, $type := .policytype }}
  - {{ $type }}
  {{- end }}
  {{- if .ingress }}
  ingress:
  - from:
  {{- range $i, $ingress := .ingress }}
    - {{ .name -}}: {{ if eq .name "podselector" }}{}{{ end -}}
      {{- if eq .name "ipblock" }}
      {{- range $k, $v := .settings }}
      cidr: {{ $v -}}
      {{ end -}}
      {{ end -}}
      {{- if eq .name "namespaceselector" }}
      {{- range $k, $v := .settings }}
      matchlabels:
        {{- range $k, $v := . }}
        {{ $k }}: {{ $v }}
        {{- end -}}
      {{ end -}}
      {{ end -}}
    {{- end }}
    ports:
    {{ range $i, $port := .ingressports }}
    {{- range $k, $v := . -}}
    {{- if eq $k "port" -}}
    - {{ $k }}: {{ $v }}
    {{- end -}}
    {{ if eq $k "protocol" }}
      {{ $k }}: {{ $v }}
    {{ end -}}
    {{ end -}}
    {{- end }}
  {{- end }}
  {{- if .egress }}
  egress:
    - to:
      ports:
  {{- end }}
{{- end }}
{{- end }}

这给了我结果:

---
# Source: network-policies/templates/extra-policies.yml
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
  name: dashur
  namespace: default
spec:
  policyTypes:
  - Ingress
  ingress:
  - from:
    - podSelector: {}
    - ipBlock: 
      cidr: 172.17.0.0/16
    - namespaceSelector: 
      matchLabels:
        namespace: mynamespace
        project: test
    ports:
    - port: 6379
      protocol: TCP
    - port: 8080
      protocol: TCP
---
# Source: network-policies/templates/extra-policies.yml
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
  name: dashur-integ
  namespace: default
spec:
  policyTypes:
  - Ingress
  ingress:
  - from:
    - podSelector: {}
    - ipBlock: 
      cidr: 172.17.0.0/16
    ports:
    - port: 3000
      protocol: TCP
    - port: 8000
      protocol: TCP
    - port: 443
      protocol: TCP
    - port: 80
      protocol: TCP

希望它可以帮助那些面临与我相同问题的人:-)

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>