Postgres部署中的环境变量无法正常工作

时间:2019-12-05 18:37:23

标签: docker kubernetes skaffold

首先,我非常确定我知道为什么这行不通:我先拉Docker postgres:11-alpine映像,对其进行修改,然后尝试在k8s中更改env: deployment.yaml在自定义图片上。我认为这就是问题所在。

基本上,我正在尝试按照Docker postgres docs来做到这一点:

docker run --name some-postgres -e POSTGRES_PASSWORD='foo' POSTGRES_USER='bar'

这就是我所拥有的:

Dockerfile.dev

FROM postgres:11-alpine
EXPOSE 5432
COPY ./db/*.sql /docker-entrypoint-initdb.d/

postgres.yaml (在我玩完此游戏后,秘密将被移动)

apiVersion: apps/v1
kind: Deployment
metadata:
  name: postgres-deployment
spec:
  replicas: 1
  selector:
    matchLabels:
      component: postgres
  template:
    metadata:
      labels:
        component: postgres
    spec:
      containers:
        - name: postgres
          image: testproject/postgres
          ports:
            - containerPort: 5432
          env: 
            - name: POSTGRES_DB
              value: "test_dev"
            - name: POSTGRES_USER
              value: "bar"
            - name: POSTGRES_PASSWORD
              value: "foo"
          volumeMounts:
            - name: postgres-storage
              mountPath: /var/lib/postgresql/data
              subPath: postgres
      volumes:
        - name: postgres-storage
          persistentVolumeClaim:
            claimName: postgres-storage
---
apiVersion: v1
kind: Service
metadata:
  name: postgres-cluster-ip-service
spec:
  type: ClusterIP
  selector:
    component: postgres
  ports:
    - port: 5432
      targetPort: 5432

但是,当我使用Skaffold在本地启动集群时,env:“不要”,因为我仍然可以使用默认值POSTGRES_USER=postgresPOSTGRES_PASSWORD=''访问数据库。

我敢打赌,如果我做了image: postgres,那么env:就可以了,但是我不确定如何做与Dockerfile中的等效:

COPY ./db/*.sql /docker-entrypoint-initdb.d/

有什么建议吗?

如果有用的话,这里是skaffold.yaml

apiVersion: skaffold/v1beta15
kind: Config
build:
  local:
    push: false
  artifacts:
    - image: testproject/postgres
      docker:
        dockerfile: ./db/Dockerfile.dev
      sync:
        manual:
          - src: "***/*.sql"
            dest: .
    - image: testproject/server
      docker:
        dockerfile: ./server/Dockerfile.dev
      sync:
        manual:
          - src: "***/*.py"
            dest: .
deploy:
  kubectl:
    manifests:
      - k8s/ingress.yaml 
      - k8s/postgres.yaml
      - k8s/server.yaml

1 个答案:

答案 0 :(得分:3)

Docker postgres docs提到以下内容:

  

警告:仅当您使用空的数据目录启动容器时,特定于Docker的变量才有效。容器启动时,所有现有数据库都将保持不变。

确定要从一个空的数据目录开始部署吗?可能是PostgreSQL启动并允许您在使用该永久性卷首次启动时使用环境变量中指定的凭据登录吗?

如果不是,请查看正在运行的pod的环境变量。 kubectl describe POD应该告诉您哪些环境变量实际上是传递给Pod的。也许Skaffold设置中的某些内容会覆盖环境变量?您可以通过在执行Pod时运行env来查看Pod。同样不要忘记日志,PostgreSQL容器应该记录它在启动期间创建的用户帐户。