4

我正在使用 Jenkins X 并尝试values.yaml根据我要推广的环境通过文件设置不同的变量。例如,当将发布从暂存升级到生产时,我希望我的存储库中的values.yaml文件environment-xxxx-production覆盖我的项目存储库中的值。

根据https://github.com/jenkins-x/jx/issues/1667#issuecomment-420901836这个评论,这应该通过将变量放在environment-xxxx-production存储库中来工作。

我的项目中的示例deployment.yaml文件。

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: {{ template "fullname" . }}
  labels:
    draft: {{ default "draft-app" .Values.draft }}
    chart: "{{ .Chart.Name }}-{{ .Chart.Version | replace "+" "_" }}"
spec:
  replicas: {{ .Values.replicaCount }}
  template:
    metadata:
      labels:
        draft: {{ default "draft-app" .Values.draft }}
        app: {{ template "fullname" . }}
{{- if .Values.podAnnotations }}
      annotations:
{{ toYaml .Values.podAnnotations | indent 8 }}
{{- end }}
    spec:
      containers:
      - name: {{ .Chart.Name }}
        image: "{{ .Values.image.repository }}:{{ .Values.image.tag }}"
        imagePullPolicy: {{ .Values.image.pullPolicy }}
        ports:
        - containerPort: {{ .Values.service.internalPort }}
{{/*
Here's the section in question.
*/}}
{{- if .Values.env }}
        env:
{{- if .Values.prBranch }}
          - name: MY_ENV
            value: "some_value"
{{- else }}
{{ toYaml .Values.env | indent 10 }}
{{- end }}
{{- end }}
        livenessProbe:
          httpGet:
            path: {{ .Values.probePath }}
            port: {{ .Values.service.internalPort }}
          initialDelaySeconds: {{ .Values.livenessProbe.initialDelaySeconds }}
          periodSeconds: {{ .Values.livenessProbe.periodSeconds }}
          successThreshold: {{ .Values.livenessProbe.successThreshold }}
          timeoutSeconds: {{ .Values.livenessProbe.timeoutSeconds }}
        readinessProbe:
          httpGet:
            path: {{ .Values.probePath }}
            port: {{ .Values.service.internalPort }}
          periodSeconds: {{ .Values.readinessProbe.periodSeconds }}
          successThreshold: {{ .Values.readinessProbe.successThreshold }}
          timeoutSeconds: {{ .Values.readinessProbe.timeoutSeconds }}
        resources:
{{ toYaml .Values.resources | indent 12 }}
      terminationGracePeriodSeconds: {{ .Values.terminationGracePeriodSeconds }}

示例项目values.yaml包含以下内容:

env:
  - name: MY_ENV
    value: "some_staging_value"

示例environment-xxxx-production values.yaml包含以下内容:

env:
- name: MY_ENV
  value: some_production_value

我当然可以让预览和暂存环境变量正常工作。但是,当我将应用程序提升到生产环境时,env 列表中的列表environment-xxxx-production不会覆盖项目本身内部文件中的env 列表。values.yaml

4

2 回答 2

5

生产values.yaml文件中的键必须是您在其中使用的图表的名称requirements.yaml- 这就是 helm 组合图表的方式。

因此,如果您的应用被调用cheese,请requirements.yaml尝试在values.yaml

cheese:
  env:
  - name: MY_ENV
    value: some_production_value
于 2019-02-19T18:49:37.590 回答
1

值得注意的是,截至今天,语法似乎已经改变。

使用 创建应用程序时jx create quickstart,如果我们查看部署模板 ( your-app/charts/your-app/templates/deployment.yaml),它会显示部署的 env 部分填充如下:

        env:
{{- range $pkey, $pval := .Values.env }}
        - name: {{ $pkey }}
          value: {{ quote $pval }}
{{- end }}

这意味着在values.yaml文件中,存在于您的 GitOps 存储库中,用于暂存、生产和应用程序存储库中的默认值;您的自定义 ENV 变量应添加为:

your-app:
  env:
    MY_ENV_VAR: "Staging value for MY_ENV_VAR"

requirements.yaml正如詹姆斯在回答中解释的那样,“your-app”是您的应用程序的名称,与 in 中的内容相匹配。

于 2019-10-23T13:29:52.130 回答