一、HostPath简介
EmptyDir中的数据不会被持久化,它会随着Pod的结束而销毁,如果想简单的将数据持久化到主机中,可以选择HostPath
HostPath就是将Node主机中的一个实际目录挂载到Pod中,以供容器使用,这样的设计就可以保证Pod销毁了,但是数据可以存在Node主机上
二、HostPath实例演示
如下,将Node节点上一个目录挂载到pod中,这样当pod销毁时,数据仍然存在,即做到了持久化存储
编辑hostpath.yaml文件,内容如下:
apiVersion: v1
kind: Namespace
metadata:
name: dev
---
apiVersion: v1
kind: Pod
metadata:
name: volume-hostpath
namespace: dev
spec:
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.yaml
namespace/dev created
pod/volume-hostpath created
[root@master Volume]#
查看创建的资源
[root@master Volume]# kubectl get pod -n dev -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
volume-hostpath 2/2 Running 1 6m18s 10.244.1.248 node1 <none> <none>
[root@master Volume]#
此时去node1节点发现已经创建了如下logs文件夹
[root@node1 ~]# ls /root/
anaconda-ks.cfg logs test.sh
[root@node1 ~]#
然后在node1节点上执行如下命令检测日志文件
tail -f /root/logs/access.log
然后去master节点连续执行三次如下请求nginx的命令
curl 10.244.1.248:80
再回到node1节点发现此时已经出现了如下打印
[root@node1 logs]# tail -f /root/logs/access.log
10.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.yaml
namespace "dev" deleted
pod "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.log
10.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]#