linux怎么查看本机内存大小
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
此时去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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~