【发布时间】:2020-06-15 18:08:05
【问题描述】:
我发布了一个与此类似的question,并试图实现这个问题的答案所说的:How to access Kubernetes container environment variables from Next.js application?
但是,当我仍然调用我的环境变量执行process.env.USERNAME 时,我仍然得到未定义的返回......我在我的部署文件中做错了什么吗?这是我的deployment.yaml的副本:
metadata:
namespace: <namespace>
releaseName: <release name>
releaseVersion: 1.0.0
target: <target>
auth:
replicaCount: 1
image:
repository: '<name of repository is here>'
pullPolicy: <always>
container:
multiPorts:
- containerPort: 443
name: HTTPS
protocol: TCP
- containerPort: 80
name: HTTP
protocol: TCP
env:
- name: USERNAME
valueFrom:
secretKeyRef:
name: my-username
key: username
- name: PASSWORD
valueFrom:
secretKeyRef:
name: my-password
key: password
- name: HOST
valueFrom:
secretKeyRef:
name: my-host
key: host
volumeMounts:
- name: config
mountPath: "/configMap"
readOnly: true
volume:
- name: config
configMap:
name: environmental-variables
resources:
requests:
cpu: 0.25
memory: 256Mi
limits:
cpu: 1
memory: 1024Mi
variables:
- name: NODE_ENV
value: <node env value here>
ingress:
enabled: true
ingressType: <ingressType>
applicationType: <application type>
serviceEndpoint: <endpoint>
multiPaths:
- path: /
- HTTPS
tls:
enabled: true
secretName: <name>
autoscale:
enabled: false
minReplicas: 1
maxReplicas: 5
cpuAverageUtilization: 50
memoryUtilizationValue: 50
annotations:
ingress:
nginx.ingress.kubernetes.io/affinity: <affinity>
nginx.ingress.kubernetes.io/session-cookie-name: <cookie-name>
nginx.ingress.kubernetes.io/session-cookie-expires: <number>
nginx.ingress.kubernetes.io/session-cookie-max-age: <number>
我还创建了一个configMap.yaml 文件,尽管我不确定这是否是正确的方法。这是我的configMap.yaml 文件:
apiVersion: v1
kind: ConfigMap
metadata:
name: environmental-variables
data:
.env: |
USERNAME: <username>
PASSWORD: <password>
HOST: <host>
任何帮助将不胜感激!此外,我试图将我的环境变量设置为 Secrets,因为我不想公开我的任何变量,因为它包含敏感信息。我正在尝试在使用 Express 的 Node.js 应用程序上执行此操作。谢谢!
编辑:这是我的 yaml 文件中 Secrets 部分的样子
secrets:
- name: environmental-variables
key: USERNAME
- name: environmental-variables
key: PASSWORD
我的 Secrets yaml 文件长什么样:
kind: Secret
apiVersion: v1
metadata:
name: environmental-variables
namespace: tda-dev-duck-dev
data:
USERNAME: <username>
PASSWORD: <password>
【问题讨论】:
-
在 ConfigMap 中查看管道字符 (
|) - 这是问题的指示符。基本上,您的 configmap 只有 1 个条目,键.env和 value 是带有 USERNAME、PASSWORD 等的多行字符串。为了能够将 ConfigMap 中的条目实际挂载为 env 变量,您需要在 configmap 的数据块中有多个条目, 每条信息 1 个条目。
标签: node.js kubernetes deployment environment-variables kubernetes-secrets