Kubernetes----HostPath类型的基本存储

网友投稿 279 2022-09-10

Kubernetes----HostPath类型的基本存储

一、HostPath简介

EmptyDir中的数据不会被持久化,它会随着Pod的结束而销毁,如果想简单的将数据持久化到主机中,可以选择HostPath

HostPath就是将Node主机中的一个实际目录挂载到Pod中,以供容器使用,这样的设计就可以保证Pod销毁了,但是数据可以存在Node主机上

二、HostPath实例演示

如下,将Node节点上一个目录挂载到pod中,这样当pod销毁时,数据仍然存在,即做到了持久化存储

编辑hostpath.yaml文件,内容如下:

apiVersion: v1kind: Namespacemetadata: name: dev---apiVersion: v1kind: Podmetadata: name: volume-hostpath namespace: devspec: containers: - name: nginx image: nginx:1.17.1 ports: - containerPort: 80 volumeMounts: - name: logs-volume mountPath: /var/log/nginx - name: busybox image: busybox:1.30 command: ["/bin/sh","-c","tail -f /logs/access.log"] volumeMounts: - name: logs-volume mountPath: /logs volumes: - name: logs-volume hostPath: path: /root/logs type: DirectoryOrCreate # 目录如果不存就创建

这里type字段的可选值如下:

DirectoryOrCreate # 目录存在就使用,不存在就先创建再使用Directory # 目录必须存在FileOrCreate # 文件存在就使用,不存在就先创建再使用File # 文件必须存在Socket # unix套接字必须存在CharDevice # 字符设备必须存在BlockDevice # 块设备必须存在

然后使用如下命令创建

[root@master Volume]# kubectl apply -f hostpath.yamlnamespace/dev createdpod/volume-hostpath created[root@master Volume]#

查看创建的资源

[root@master Volume]# kubectl get pod -n dev -o wideNAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATESvolume-hostpath 2/2 Running 1 6m18s 10.244.1.248 node1 [root@master Volume]#

此时去node1节点发现已经创建了如下logs文件夹

[root@node1 ~]# ls /root/anaconda-ks.cfg logs test.sh[root@node1 ~]#

然后在node1节点上执行如下命令检测日志文件

tail

然后去master节点连续执行三次如下请求nginx的命令

curl 10.244.1.248:80

再回到node1节点发现此时已经出现了如下打印

[root@node1 logs]# tail -f /root/logs/access.log10.244.0.0 - - [07/Apr/2022:13:45:06 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"

此时,回到master节点,使用如下命令删除pod资源

[root@master Volume]# kubectl delete -f hostpath.yamlnamespace "dev" deletedpod "volume-hostpath" deleted[root@master Volume]#

此时,再次回到node1节点,发现此时 /root/logs/log.access.log文件依然存在,而且内容也未消失

[root@node1 logs]# ls /root/logs/access.log error.log[root@node1 logs]# cat /root/logs/access.log10.244.0.0 - - [07/Apr/2022:13:45:06 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"[root@node1 logs]#

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:休克文案:这组「不理解」文案,很绝!
下一篇:Kubernetes----EmptyDir类型的基本存储
相关文章

 发表评论

暂时没有评论,来抢沙发吧~