【云原生 Kubernetes 系列】K8s 实战 如何给应用注入数据 II 将pod数据传递给容器_pod容器传参

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

restartPolicy: Never


这个配置文件中,你可以看到四个环境变量。env 字段是一个 `EnvVars.` 对象的数组。数组中第一个元素指定 **MY\_CPU\_REQUEST** 这个环境变量从 Container 的 `requests.cpu` 字段获取变量值。同样,其它环境变量也是从 Container 的字段获取它们的变量值。


1. 创建Pod:



$ kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-container.yaml


2. 验证 Pod 中的容器运行正常:



$ kubectl get pods


3. 查看容器日志:



$ kubectl logs dapi-envars-resourcefieldref


4. 输出信息显示了所选择的环境变量的值:



> 
> 1  
>  1  
>  33554432  
>  67108864
> 
> 
> 


## 二、通过文件将 Pod 信息呈现给容器


前面我们学习了使用环境变量的方式,现在我们学习通过文件的方式。  
 在目录 `pods/inject/dapi-volume.yaml` 中创建一个包含一个容器的 Pod,并将 Pod 级别的字段作为文件映射到正在运行的容器中。 Pod 的清单如下:



apiVersion: v1
kind: Pod
metadata:
name: kubernetes-downwardapi-volume-example
labels:
zone: us-est-coast
cluster: test-cluster1
rack: rack-22
annotations:
build: two
builder: john-doe
spec:
containers:
- name: client-container
image: k8s.gcr.io/busybox
command: [“sh”, “-c”]
args:
- while true; do
if [[ -e /etc/podinfo/labels ]]; then
echo -en ‘\n\n’; cat /etc/podinfo/labels; fi;
if [[ -e /etc/podinfo/annotations ]]; then
echo -en ‘\n\n’; cat /etc/podinfo/annotations; fi;
sleep 5;
done;
volumeMounts:
- name: podinfo
mountPath: /etc/podinfo
volumes:
- name: podinfo
downwardAPI:
items:
- path: “labels”
fieldRef:
fieldPath: metadata.labels
- path: “annotations”
fieldRef:
fieldPath: metadata.annotations


在 Pod 清单中,你可以看到 Pod 有一个 downwardAPI 类型的卷,并且挂载到容器中的 /etc/podinfo 目录。


查看 downwardAPI 下面的 items 数组。 数组的每个元素定义一个 downwardAPI 卷。 第一个元素指示 Pod 的 metadata.labels 字段的值保存在名为 labels 的文件中。 第二个元素指示 Pod 的 annotations 字段的值保存在名为 annotations 的文件中。


1. 创建 Pod:



$ kubectl apply -f https://k8s.io/examples/pods/inject/dapi-volume.yaml


2. 验证Pod中的容器运行正常:



$ kubectl get pods


3. 查看容器的日志:



$ kubectl logs kubernetes-downwardapi-volume-example


4. 输出显示 labels 和 annotations 文件的内容:



> 
> cluster=“test-cluster1”  
>  rack=“rack-22”  
>  zone=“us-est-coast”
> 
> 
> build=“two”  
>  builder=“john-doe”
> 
> 
> 


5. 进入 Pod 中运行的容器,打开一个 Shell:



$ kubectl exec -it kubernetes-downwardapi-volume-example – sh


6. 在该 Shell中,查看 labels 文件:



> 
> /# cat /etc/podinfo/labels
> 
> 
> 


7. 输出显示 Pod 的所有标签都已写入 labels 文件。



> 
> cluster=“test-cluster1”  
>  rack=“rack-22”  
>  zone=“us-est-coast”
> 
> 
> 


8. 同样,查看 annotations 文件:



> 
> /# cat /etc/podinfo/annotations
> 
> 
> 


9. 查看 /etc/podinfo 目录下的文件:



> 
> /# ls -laR /etc/podinfo
> 
> 
> 


在输出中可以看到,labels 和 annotations 文件都在一个临时子目录中。 在这个例子,…2982\_06\_02\_21\_47\_53.299460680。 在 /etc/podinfo 目录中,…data 是一个指向临时子目录 的符号链接。/etc/podinfo 目录中,labels 和 annotations 也是符号链接。



> 
> drwxr-xr-x … Feb 6 21:47 …2982\_06\_02\_21\_47\_53.299460680  
>  lrwxrwxrwx … Feb 6 21:47 …data -> …2982\_06\_02\_21\_47\_53.299460680  
>  lrwxrwxrwx … Feb 6 21:47 annotations -> …data/annotations  
>  lrwxrwxrwx … Feb 6 21:47 labels -> …data/labels
> 
> 
> 



> 
> /etc/…2982\_06\_02\_21\_47\_53.299460680:  
>  total 8  
>  -rw-r–r-- … Feb 6 21:47 annotations  
>  -rw-r–r-- … Feb 6 21:47 labels
> 
> 
> 


用符号链接可实现元数据的动态原子性刷新;更新将写入一个新的临时目录, 然后通过使用 rename(2) 完成 …data 符号链接的原子性更新。


10. 退出 Shell:



> 
> /# exit
> 
> 
> 


### 2.1、存储容器字段


使用 downward API 使 Pod 级别的字段可以被 Pod 内正在运行的容器访问。 接下来我们将只传递由 Pod 定义的部分的字段到 Pod 内正在运行的容器中,但这些字段取自特定容器而不是整个 Pod。 下面是目录 `pods/inject/dapi-volume-resources.yaml` 中一个同样只有一个容器的 Pod 的清单:



apiVersion: v1
kind: Pod
metadata:
name: kubernetes-downwardapi-volume-example-2
spec:
containers:
- name: client-container
image: k8s.gcr.io/busybox:1.24
command: [“sh”, “-c”]
args:
- while true; do
echo -en ‘\n’;
if [[ -e /etc/podinfo/cpu_limit ]]; then
echo -en ‘\n’; cat /etc/podinfo/cpu_limit; fi;
if [[ -e /etc/podinfo/cpu_request ]]; then
echo -en ‘\n’; cat /etc/podinfo/cpu_request; fi;
if [[ -e /etc/podinfo/mem_limit ]]; then
echo -en ‘\n’; cat /etc/podinfo/mem_limit; fi;
if [[ -e /etc/podinfo/mem_request ]]; then
echo -en ‘\n’; cat /etc/podinfo/mem_request; fi;
sleep 5;
done;
resources:
requests:
memory: “32Mi”
cpu: “125m”
limits:
memory: “64Mi”
cpu: “250m”
volumeMounts:
- name: podinfo
mountPath: /etc/podinfo
volumes:
- name: podinfo
downwardAPI:
items:
- path: “cpu_limit”
resourceFieldRef:
containerName: client-container
resource: limits.cpu
divisor: 1m
- path: “cpu_request”
resourceFieldRef:
containerName: client-container
resource: requests.cpu
divisor: 1m
- path: “mem_limit”
resourceFieldRef:
containerName: client-container
resource: limits.memory
divisor: 1Mi
- path: “mem_request”
resourceFieldRef:
containerName: client-container
resource: requests.memory
divisor: 1Mi


在这个清单中,你可以看到 Pod 有一个 downwardAPI 卷, 并且这个会挂载到 Pod 内的单个容器的 /etc/podinfo 目录。


查看 downwardAPI 下面的 items 数组。 数组的每个元素定义一个 downwardAPI 卷。


第一个元素指定在名为 client-container 的容器中, 以 1m 所指定格式的 limits.cpu 字段的值应推送到名为 cpu\_limit 的文件中。 divisor 字段是可选的,默认值为 1,1 的除数表示 CPU 资源的核心或内存资源的字节。


1. 创建Pod:



$ kubectl apply -f https://k8s.io/examples/pods/inject/dapi-volume-resources.yaml


2. 打开一个 Shell,进入 Pod 中运行的容器:



$ kubectl exec -it kubernetes-downwardapi-volume-example-2 – sh


3. 在 Shell 中,查看 cpu\_limit 文件:



在容器内的 Shell 中运行

$ cat /etc/podinfo/cpu_limit


你可以使用同样的命令查看 `cpu_request、mem_limit 和 mem_request` 文件.


## 总结


本篇文章,主要是为了总结学习上一篇的内容,在此文章中,我们学会了如何使用环境变量的方式、通过文件的方式,来为容器传递数据,那么下一篇,我们将一起学习如何使用 Secret 来安全的分发数据内容,期待我们的下次再见。





![img](https://img-blog.csdnimg.cn/img_convert/ef8ba155fcbd89ede5a3df8d502de93d.png)
![img](https://img-blog.csdnimg.cn/img_convert/ce4871afae527894a4b569808512ce7a.png)
![img](https://img-blog.csdnimg.cn/img_convert/35aa7596c750c47e54cfc116bf0b0446.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

 Secret 来安全的分发数据内容,期待我们的下次再见。





[外链图片转存中...(img-1Jkqd3vh-1715707093415)]
[外链图片转存中...(img-vXyCq7t1-1715707093416)]
[外链图片转存中...(img-6RqhdaNr-1715707093416)]

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值