无法从发布清单构建kubernetes对象

问题描述 投票:0回答:1

我正在尝试如下部署港口:

helm install hub harbor/harbor \
  --namespace prod \
  --set expose.ingress.hosts.core=hub.service.example.io \
  --set expose.ingress.annotations.'kubernetes\.io/ingress\.class'=contour \
  --set expose.ingress.annotations.'cert-manager\.io/cluster-issuer'=letsencrypt-prod \
  --set expose.ingress.annotations.'ingress\.kubernetes\.io/force-ssl-redirect'="true" \
  --set expose.ingress.annotations.'kubernetes\.io/tls-acme'="true" \
  --set externalURL=https://hub.service.example.io \
  --set expose.tls.secretName=secret \
  --set notary.enabled=false \
  --set secretkey=secret \
  --set harborAdminPassword=serect  

我有:

Error: unable to build kubernetes objects from release manifest: unable to decode "": resource.metadataOnlyObject.ObjectMeta: v1.ObjectMeta.Annotations: ReadString: expects " or n, but found t, error found in #10 byte of ...|edirect":true,"ingre|..., bigger context ...|prod","ingress.kubernetes.io/force-ssl-redirect":true,"ingress.kubernetes.io/proxy-body-size":"0","i|...  

我做错了什么?

kubernetes kubernetes-ingress
1个回答
0
投票

您需要使用--set-string来设置布尔注释值,如下所示

helm install hub harbor/harbor \
 --namespace prod \
 --set expose.ingress.hosts.core=hub.service.example.io \
 --set expose.ingress.annotations.'kubernetes\.io/ingress\.class'=contour \
 --set expose.ingress.annotations.'cert-manager\.io/cluster-issuer'=letsencrypt-prod \
 --set-string expose.ingress.annotations.'ingress\.kubernetes\.io/force-ssl-redirect'="true" \
 --set-string expose.ingress.annotations.'kubernetes\.io/tls-acme'="true" \
 --set externalURL=https://hub.service.example.io \
 --set expose.tls.secretName=secret \
 --set notary.enabled=false \
 --set secretkey=secret \
 --set harborAdminPassword=serect 
© www.soinside.com 2019 - 2024. All rights reserved.