Kubernetes env 变量在 sequelize-cli 中不起作用



我正在尝试运行以下命令:

npx sequelize-cli db:migrate

sequelize-cli使用包含以下内容的./config/config.js文件:

module.exports = {
username: process.env.PGUSER,
host: process.env.PGHOST,
database: process.env.PGDATABASE,
password: process.env.PGPASSWORD,
port: process.env.PGPORT,
};

如果你console.log()你所有的process.env.<var>,一切都会undefined回来。

但是,如果进入 Express 应用程序所在的index.jsconsole.log相同的操作,它将返回预期值。

在所有这些过程中,我让Kubernete与skaffold.yamlminikube一起运行。

有没有办法在不创建仅运行这些命令.env的情况下使其工作?

server-deployment.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
name: server-deployment
spec:
replicas: 3
selector:
matchLabels:
component: server
template:
metadata:
labels:
component: server
spec:
containers:
- name: server
image: sockpuppet/server
ports:
- containerPort: 5000
env:
- name: PGUSER
value: postgres
- name: PGHOST
value: postgres-cluster-ip-service
- name: PGPORT
value: '5432'
- name: PGDATABASE
value: postgres
- name: PGPASSWORD
value: ''

嗯,它并不漂亮,但这是我能弄清楚的最好的。希望有人有更好的答案...

由于这是一个由三个副本组成的deployment,因此它会生成三个 Pod。必须先获取一个 ID:

kubectl get pod

一旦我有了它,我就可以执行以下操作:

kubectl exec -it server-deployment-84cf685559-gwkvt -- npx sequelize-cli db:migrate

这行得通,但有点混乱。

遇到了这个更有效的链接,特别是如果只是做一个alias

kubectl exec -it $(kubectl get pods -o name | grep -m1 INSERT_DEPLOYMENT_NAME_HERE | cut -d'/' -f 2) INSERT_YOUR_COMMAND_HERE
kubectl exec -it $(kubectl get pods -o name | grep -m1 server-deployment | cut -d'/' -f 2) "npx sequelize-cli db:migrate" 

最新更新