我正在试着为我们的产品写头盔图表。这些图像存储在GCR私有存储库中。所有组件的图表都已准备就绪,但我正尝试在imagePullSecrets的图表中编写一个YAML文件。我读过来自here的图表提示,
我还知道如何使用以下命令创建imagePullSecret:
kubectl create secret docker-registry mydockercfg \
--docker-server "https://eu.gcr.io" \
--docker-username _json_key \
--docker-email not@val.id \
--docker-password=$(cat your_service_account.json)
但是我不知道如何在该图表的values.yaml密码中填入"your_service_account.json“的内容。更好的做法是,我可以更改名称"your_service_account.json“来更新values.yaml的密码。
目前,我的实现如下:
$ cat values.yaml
secretName: gcr-json-key-test
imageCredentials:
registry: us.gcr.io/xxxxx
username: _json_key
password:
Secrets.yaml的内容:
$ cat templates/secrets.yaml
apiVersion: v1
kind: Secret
metadata:
name: {{ .Values.secretName }}
labels:
app: {{ template "fullname" . }}
chart: "{{ .Chart.Name }}-{{ .Chart.Version }}"
release: "{{ .Release.Name }}"
heritage: "{{ .Release.Service }}"
type: kubernetes.io/dockercfg
data:
.dockerconfigjson: {{ template "imagePullSecret" . }}
_helpers.tpl的内容:
$ cat templates/_helpers.tpl
{{/*
Expand the name of the chart.
*/}}
{{- define "name" -}}
{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}}
{{- end -}}
{{/*
Create a default fully qualified app name.
We truncate at 63 chars because some Kubernetes name fields are limited
to this (by the DNS naming spec).
*/}}
{{- define "fullname" -}}
{{- $name := default .Chart.Name .Values.nameOverride -}}
{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" -}}
{{- end -}}
{{- define "imagePullSecret" }}
{{- printf "{\"auths\": {\"%s\": {\"auth\": \"%s\"}}}" .Values.imageCredentials.registry (printf "%s:%s" .Values.imageCredentials.username .Values.imageCredentials.password | b64enc) | b64enc }}
{{- end }}
然后使用
$ helm install ./secrets --set imageCredentials.password "$(cat ./my_service_account.json)"
将导致错误:
错误:此命令需要1个参数:图表名称
我该如何解决这个问题?
https://stackoverflow.com/questions/46946946
复制相似问题