k8s中Chart模板流程控制if_with_range和变量

Chart模板流程控制if_with_range和变量

1)if

修改values.yaml

复制代码
cat > values.yaml <<EOF
myname: aming
service:
  type: ClusterIP
  port: 80
  myport: 8080
EOF

修改service.yaml

复制代码
cat > templates/service.yaml <<EOF
apiVersion: v1
kind: Service
metadata:
  name: testserivce
  labels:
    app: myapp
spec:
  type: {{ .Values.service.type }}
  ports:
    {{- if eq .Values.web "nginx" }}
    - port: {{ .Values.service.port }}
    {{- else }}
    - port: {{ .Values.service.myport }}
    {{- end }}
      targetPort: http
      protocol: TCP
      name: http
EOF

说明:在if else end 左边加-,是为了去掉空行。{{- 表示删除左边的所有空格,直到非空格字符,而 -}}表示删除右边的所有空格。注意,换行符也是空格,当然还包括空格,TAB字符

渲染

复制代码
helm template testrelease . --set web=nginx

  ports:
    - port: 80

如果不定义web变量的值,port为8080

复制代码
helm template testrelease .

  ports:
    - port: 8080

2)with 限定作用域

with 的语法类似简单的 if:

复制代码
{{ with PIPELINE }}
  # restricted scope
{{ end }}

没有用 with 的例子:

values.yaml:

复制代码
env:
  host: localhost
  user: test
  hello: world

deployment.yaml 的引用:

复制代码
       {{- if .Values.env }}
        env:
        - name: host
          value: {{ .Values.env.host }}
        - name: user
          value: {{ .Values.env.user }}
        - name: hello
          value: {{ .Values.env.hello }}
        {{- end }}

上面的变量引用都需要从.Values开始, 有点繁琐。

with 的例子:

deployment.yaml 添加 with 以后:

复制代码
       {{- with .Values.env }}
        env:
        - name: host
          value: {{ .host }}
        - name: user
          value: {{ .user }}
        - name: hello
          value: {{ .hello }}
        {{- end }}

with 语句块里, 把当前范围定义在了.Values.env这个变量上了。

渲染后结果:

复制代码
env:
 - name: host
   value: localhost
 - name: user
   value: test
 - name: hello
   value: world

3)range 实现循环

在values.yaml 文件中添加上一个变量列表:

复制代码
cat > values.yaml <<EOF
myname: aming
service:
  type: ClusterIP
  port: 80
  myport: 8080
test:
  - 1
  - 2
  - 3
EOF

循环打印该列表:

复制代码
cat > templates/configmap.yaml <<EOF
apiVersion: v1
kind: ConfigMap
metadata:
  name: {{ .Release.Name }}-configmap
data:
  myvalue: "Hello World"
  myname: {{ quote .Values.myname }}
  test: |
  {{- range .Values.test }}
    - {{ . }}   ##遍历循环打印所有元素
  {{- end }}
EOF

渲染

复制代码
helm template testrelease .

  test: |
    - 1
    - 2
    - 3

Chart模板中的变量

变量在模板中,使用变量的场合不多,但个别情况下不得不使用变量。

问题 1:获取数组键值

values.yaml

复制代码
env:
  NAME: "gateway"
  JAVA_OPTS: "-Xmx1G"

deployment.yaml

复制代码
...
env:
  {{- range $k, $v := .Values.env }}
    - name: {{ $k }}
      value: {{ $v | quote }}
   {{- end }}

结果如下

复制代码
env:
  - name: JAVA_OPTS
    value: "-Xmx1G"
  - name: NAME
    value: "gateway"

上面在 range 循环中使用 k 和 v 两个变量来接收后面列表循环的键和值。

问题 2:with 中不能使用内置对象

with 语句块内不能带 .Release.Name 对象,否则报错。我们可以将该对象赋值给一个变量可以来解决这个问题:

复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  name: {{ .Release.Name }}-deployment
spec:
  replicas: {{ .Values.replicas }}
  template:
metadata:
  labels:
    project: {{ .Values.label.project }}
    app: {{ quote .Values.label.app }}
   {{- with .Values.label }}
     project: {{ .project }}
     app: {{ .app }}
     release: {{ .Release.Name }}
    {{- end }}
相关推荐
吃瓜群众i几秒前
Javascript的核心知识点-函数
前端·javascript
zhujiaming几秒前
鸿蒙端应用适配使用开源flutter值得注意的一些问题
前端·flutter·harmonyos
前端付豪1 分钟前
8、鸿蒙动画开发实战:做一个会跳舞的按钮!(附动效示意图)
前端·后端·harmonyos
前端付豪2 分钟前
3、构建你的第一个鸿蒙组件化 UI 页面:实现可复用的卡片组件(附实战代码)
前端·后端·harmonyos
言诺意深4 分钟前
leaflet地图库-初始化(1)
前端
前端付豪4 分钟前
7、打造鸿蒙原生日历组件:自定义 UI + 数据交互(附实操案例与效果图)
前端·后端·harmonyos
没有鸡汤吃不下饭4 分钟前
解决vite+vue3运行项目打开页面跳转很慢打不开需要刷新问题:optimized dependencies change. reloading
前端·vue.js·vite
ZhZhXuan4 分钟前
点击按钮没反应?其实是样式bug
前端·css
言诺意深5 分钟前
使用 Vue2 + Leaflet 快速搭建一个交互式地图(含标记、圆形、多边形)2
前端
niesiyuan0005 分钟前
MAC如何安装多版本jdk(以8,11,17为例)
java