0

我们正在从头开始一个项目,该项目将在谷歌云服务上进行管理。我想使用 Google Kubernetes Engine。我们的应用程序将有多个环境(Dev、Staging、Production)。每个环境都设置为 Google Cloud 上的一个新项目。

我不清楚的是如何参数化我们的服务/清单文件。例如我们下面的部署文件,{}我想从每个环境的变量列表中提取任何内容。在之前的一篇文章中,有人提到使用 Helm,但我找不到太多支持以这种方式使用 helm 的文档。

apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: webapp
spec:
  replicas: 1
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxSurge: {max-surge}
      maxUnavailable: 0
  selector:
    matchLabels:
      run: webapp
  template:
    metadata:
      labels:
        run: webapp
    spec:
      containers:
      - name: webapp
        image: {gcr-image-url}
        imagePullPolicy: Always
        ports:
        - containerPort: 3000
        env:
        - name: DATABASE_URL
          valueFrom:
            secretKeyRef:
              name: app-secrets
              key: DATABASE_URL
        - name: SECRET_KEY_BASE
          valueFrom:
            secretKeyRef:
              name: app-secrets
              key: SECRET_KEY_BASE

有哪些工具可用于管理我的 GKE 环境?我们将使用 terraform 进行基础设施管理,但我是否可以使用更大的包装器来设置每个环境的参数?

4

2 回答 2

2

Helm 可以为此工作,kustomize 也可以。在 helm 的情况下,您将拥有单独的 values.yaml 文件(例如 dev-values.yaml),例如:

max-surge: 2
gcr-image-url: project-23456/test

然后通过以下方式在 yaml 中引用它们:

{{ .Values.max-surge }}

安装时您将使用helm upgrade --install my-app . --values=dev-values.yaml

于 2019-06-10T19:36:08.737 回答
1

https://get-ytt.io可能是一个解决方案。

特别是如果您查看这个 github 讨论,您会注意到您可以配置您的环境,然后以标志或环境变量的形式传递值。

在您的示例中,给出以下内容config.yml

#@ load("@ytt:data", "data")

apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: webapp
  annotations:
    environment: #@ data.values.env
spec:
  replicas: 1
  strategy:
    type: RollingUpdate
    rollingUpdate:
      maxSurge: #@ data.values.max_surge
      maxUnavailable: 0
  selector:
    matchLabels:
      run: webapp
  template:
    metadata:
      labels:
        run: webapp
    spec:
      containers:
      - name: webapp
        image: #@ data.values.gcr_image_url
        imagePullPolicy: Always
        ports:
        - containerPort: 3000
        env:
        - name: DATABASE_URL
          valueFrom:
            secretKeyRef:
              name: app-secrets
              key: DATABASE_URL
        - name: SECRET_KEY_BASE
          valueFrom:
            secretKeyRef:
              name: app-secrets
              key: SECRET_KEY_BASE

values.yml

#@data/values
---
env: staging
max-surge: 1
gcr-image-url: some/other-image:latest

假设所有内容都在同一个目录中,您可以使用以下模板config.yml

ytt -f .

或从 env vars 和命令行参数动态自定义值:

export CUSTOM_env=production
ytt -f . \
  --data-value max_surge=10 \
  --data-value gcr_image_url=some/image:1.0 \
  --data-values-env CUSTOM
于 2019-06-11T17:01:23.940 回答