涨薪技术|Kubernetes(k8s)之Pod环境变量

01Pod设置环境变量

在创建pod时,可以为其下的容器设置环境变量,通过配置文件的env或envForm字段来设置环境变量。

编写pod_env.yaml文件,内容如下,通过env关键字来定义环境变量,环境变量通过name,value对来设置,如下:

复制代码
apiVersion: v1kind: Namespacemetadata:name: dev---apiVersion: v1kind: Podmetadata:name: pod-envnamespace: devlabels:user: redrose2100spec:containers:- name: nginximage: nginx:1.17.1env:- name: "username"value: "admin"- name: "password"value: "admin123"

使用如下命令创建资源​​​​​​​

复制代码
[root@master pod]# kubectl apply -f pod_env.yamlnamespace/dev createdpod/pod-env created[root@master pod]#

进入容器查看环境变量​​​​​​​

复制代码
[root@master pod]# kubectl get pod -n devNAME READY STATUS RESTARTS AGEpod-env 1/1 Running 0 3m[root@master pod]# kubectl exec pod-env -n dev -it -c nginx /bin/bashkubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a futureversion. Use kubectl exec [POD] -- [COMMAND] instead.root@pod-env:/# echo $usernameadminroot@pod-env:/# echo $passwordadmin123root@pod-env:/#

02使用pod字段作为环境变量的值

创建一个yaml文件,文件名为dapi-envars-pod.yaml,并填入以下内容:​​​​​​​

复制代码
apiVersion: v1kind: Podmetadata:name: dapi-envars-fieldrefspec:containers:- name: test-containerimage: k8s.gcr.io/busyboxcommand: [ "sh", "-c"]args:- while true; doecho -en '\n';printenv MY_NODE_NAME MY_POD_NAME MY_POD_NAMESPACE;printenv MY_POD_IP MY_POD_SERVICE_ACCOUNT;sleep 10;done;env:- name: MY_NODE_NAMEvalueFrom:fieldRef:fieldPath: spec.nodeName- name: MY_POD_NAMEvalueFrom:fieldRef:fieldPath: metadata.name- name: MY_POD_NAMESPACEvalueFrom:fieldRef:fieldPath: metadata.namespace- name: MY_POD_IPvalueFrom:fieldRef:fieldPath: status.podIP- name: MY_POD_SERVICE_ACCOUNTvalueFrom:fieldRef:fieldPath: spec.serviceAccountNamerestartPolicy: Never

在配置文件中,您可以看到五个环境变量。env 字段是 EnvVars 的数组。数组中的第一个元素指定MY_NODE_NAME 环境变量从 Pod 的 spec.nodeName 字段中获取其值。其他环境变量也类似从Pod 字段中获取它们的名称。

注意:示例中的字段是 Pod 的字段,它们不是 Pod 中的容器的字段。

创建 Pod:​​​​​​​

复制代码
kubectl create -f https://k8s.io/docs/tasks/inject-data-application/dapi-envarspod.yaml

验证 Pod 中的容器是 running 状态:

复制代码
kubectl get pods

查看容器日志:

复制代码
kubectl logs dapi-envars-fieldref

输出显示选定的环境变量的值:​​​​​​​

复制代码
minikubedapi-envars-fieldrefdefault172.17.0.4default

想要知道为什么这些值会打印在日志中,请查看配置文件的 command 和 args 字段。当容器启动时,它将 5 个环境变量的值写到标准输出中,每十秒钟重复一次。

接下来,将一个 shell 放入正在您的 Pod 中运行的容器里面:

复制代码
kubectl exec -it dapi-envars-fieldref -- sh

在 shell 中,查看环境变量:

复制代码
/# printenv

输出结果显示,某些环境变量已被指定为 Pod 字段的值:​​​​​​​

复制代码
MY_POD_SERVICE_ACCOUNT=default...MY_POD_NAMESPACE=defaultMY_POD_IP=172.17.0.4...MY_NODE_NAME=minikube...MY_POD_NAME=dapi-envars-fieldref

03使用容器字段作为环境变量的值

创建dapi-envars-container.yaml文件,用于将容器字段作为环境变量的值。​​​​​​​

复制代码
apiVersion: v1kind: Podmetadata:name: dapi-envars-resourcefieldrefspec:containers:- name: test-containerimage: k8s.gcr.io/busybox:1.24command: [ "sh", "-c"]args:- while true; doecho -en '\n';printenv MY_CPU_REQUEST MY_CPU_LIMIT;printenv MY_MEM_REQUEST MY_MEM_LIMIT;sleep 10;done;resources:requests:memory: "32Mi"cpu: "125m"limits:memory: "64Mi"cpu: "250m"env:- name: MY_CPU_REQUESTvalueFrom:resourceFieldRef:containerName: test-containerresource: requests.cpu- name: MY_CPU_LIMITvalueFrom:resourceFieldRef:containerName: test-containerresource: limits.cpu- name: MY_MEM_REQUESTvalueFrom:resourceFieldRef:containerName: test-containerresource: requests.memory- name: MY_MEM_LIMITvalueFrom:resourceFieldRef:containerName: test-containerresource: limits.memoryrestartPolicy: Never

配置文件中,您可以看到四个环境变量。env 字段是 EnvVars 的数组。数组中的第一个元素指定MY_CPU_REQUEST 环境变量从名为 test-container 的容器的 requests.cpu 字段中获取其值。其他环境变量也类似从容器字段中获取它们的值。

创建 Pod:

复制代码
kubectl create -f dapi-envars-container.yaml

验证 Pod 中的容器是 running 状态:

复制代码
kubectl get pods

查看容器日志:

复制代码
kubectl logs dapi-envars-resourcefieldref

输出展示了选定环境变量的值:​​​​​​​

复制代码
113355443267108864
相关推荐
Dicky-_-zhang2 小时前
系统容量规划与压测实战:从1万到100万QPS的科学扩容
java·jvm
console.log('npc')2 小时前
Windows 11 安装 WSL2 + Ubuntu + Docker + Codex + Sub2API 教学
windows·docker·powershell·ubantu·codex
仙柒4154 小时前
Docker原理
运维·docker·容器
Dicky-_-zhang8 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进
java·jvm
晨曦中的暮雨8 小时前
4.15腾讯 CSIG云服务产线 一面
java·开发语言
fake_ss1988 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法
茉莉玫瑰花茶8 小时前
工作流的常见模式 [ 1 ]
java·服务器·前端
未若君雅裁8 小时前
Spring AOP、日志切面与声明式事务原理
java·后端·spring
Cat_Rocky9 小时前
Kubernetes集群升级指南以及自动更新证书
云原生·容器·kubernetes
米高梅狮子9 小时前
第2章 docker容器
运维·docker·云原生·容器·架构·kubernetes·自动化