首先,我非常确定我知道为什么这行不通:我先拉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=postgres
和POSTGRES_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
答案 0 :(得分:3)
Docker postgres docs提到以下内容:
警告:仅当您使用空的数据目录启动容器时,特定于Docker的变量才有效。容器启动时,所有现有数据库都将保持不变。
确定要从一个空的数据目录开始部署吗?可能是PostgreSQL启动并允许您在使用该永久性卷首次启动时使用环境变量中指定的凭据登录吗?
如果不是,请查看正在运行的pod的环境变量。 kubectl describe POD
应该告诉您哪些环境变量实际上是传递给Pod的。也许Skaffold设置中的某些内容会覆盖环境变量?您可以通过在执行Pod时运行env
来查看Pod。同样不要忘记日志,PostgreSQL容器应该记录它在启动期间创建的用户帐户。