执行舵图时出现以下错误。
错误:helmcharts/templates/route.yaml 上的 YAML 解析错误:将 YAML 转换为 JSON 时出错:yaml:第 25 行:找不到预期的“:”
如果我从 Values.yaml 文件中删除多行字符串“|-”,同时将证书引用到 route.yaml,则该图表工作正常。由于我删除了“|-”,因此在将证书内容复制到 route.yaml 并且无法创建路由时,证书内容不会保留适当的缩进。
key: <--- works if I don't provide multiline "|-"
-----BEGIN CERTIFICATE-----
[...]
-----END CERTIFICATE-----
certificate:
-----BEGIN CERTIFICATE-----
[...]
-----END CERTIFICATE-----
caCertificate:
-----BEGIN CERTIFICATE-----
[...]
-----END CERTIFICATE-----
我该如何解决这个问题?在 values.yaml 文件中提供证书内容并将其传递给 route.yaml 是否是正确的方法。在 Ingress 的情况下,只需创建一个 tls 机密对象并在 values.yaml 中传递文件名非常简单,但是我们如何在 openshift 路由中实现相同的目标呢?
值.yaml
route:
Enabled: true
annotations:
haproxy.router.openshift.io/cookie_name: SESSION_XLD
haproxy.router.openshift.io/disable_cookies: "false"
haproxy.router.openshift.io/rewrite-target: /
path: /
hosts:
- www.example.com
tls:
key: |- <--- Doesn't work if i provide this "|-"
-----BEGIN CERTIFICATE-----
[...]
-----END CERTIFICATE-----
certificate: |- <--- Doesn't work if I provide this "|-"
-----BEGIN CERTIFICATE-----
[...]
-----END CERTIFICATE-----
caCertificate: |- <--- Doesn't work if i provide this "|-"
-----BEGIN CERTIFICATE-----
[...]
-----END CERTIFICATE-----
insecureEdgeTerminationPolicy: Redirect
路由.yaml
25 {{- if $.Values.route.tls }}
26 tls:
27 {{- with $.Values.route.tls }}
28 key: |-
29 {{ .key }}
30 certificate: |-
31 {{ .certificate }}
32 caCertificate: |-
33 {{ .caCertificate }}
34 insecureEdgeTerminationPolicy: {{ .insecureEdgeTerminationPolicy }}
35 {{- end }}
36 termination: edge
37 {{- end }}