K8S持久化存储-hostPath 卷的存储
【代码】K8S持久化存储-hostPath 卷的存储。
·
1. hostPath
hostPath Volume 是指 Pod 挂载宿主机上的目录或文件。 hostPath Volume 使得容器可以使用宿主机的文件系统进行存储 , hostpath (宿主机路径):节点级别的存储卷,在 pod 被删除,这个存储卷还是存在的,不会被删除,所以只要同一个 pod 被调度到同一个节点上来,在 pod 被删除重新被调度到这个节点之后,对应的数据依然是存在的。
2. hostPath 配置示例
cat > hostPath.yaml << EOF
apiVersion: v1
kind: Pod
metadata:
name: test-hostpath
spec:
containers:
- image: nginx
imagePullPolicy: IfNotPresent
name: test-nginx
volumeMounts:
- mountPath: /test-nginx
name: test-hostpath-volume
- image: mysql:5.7
imagePullPolicy: IfNotPresent
name: test-mysql
ports:
- containerPort: 3306 # 容器应用监听的端口号
env:
- name: MYSQL_ROOT_PASSWORD # 设置mysql的初始化密码
value: "123456" # 设置mysql的初始化密码
volumeMounts:
- mountPath: /test-mysql
name: test-hostpath-volume
volumes:
- name: test-hostpath-volume
hostPath:
path: /data1
type: DirectoryOrCreate
EOF
kubectl apply -f hostPath.yaml
kubectl get pods -o wide #pod容器分配到k8s-node1上,后期需要进入该节点的宿主机
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
test-hostpath 2/2 Running 0 56s 10.244.36.77 k8s-node1 <none> <none>
3. 验证存储
3.1 进入pod中的nginx容器
[root@k8s-master mqq]# kubectl exec -it test-hostpath -c test-nginx -- /bin/bash
root@test-hostpath:/# ls #查看目录,发现有我们容器中创建的test-nginx目录
bin boot dev docker-entrypoint.d docker-entrypoint.sh etc home lib lib64 media mnt opt proc root run sbin srv sys test-nginx tmp usr var
root@test-hostpath:/# cd /test-nginx/
root@test-hostpath:/test-nginx# ls #目录为空
root@test-hostpath:/test-nginx# touch nginx.txt #创建一个空文件,方便宿主机验证
3.2 进入pod中的mysql容器
[root@k8s-master ~]# kubectl exec -it test-hostpath -c test-mysql -- /bin/bash
root@test-hostpath:/# ls #查看目录,发现有我们容器中创建的test-mysql目录
bin boot dev docker-entrypoint-initdb.d entrypoint.sh etc home lib lib64 media mnt opt proc root run sbin srv sys test-mysql tmp usr var
root@test-hostpath:/# cd /test-mysql/
root@test-hostpath:/test-mysql# ls #目录为空
root@test-hostpath:/test-mysql# touch mysql.txt #创建一个空文件,方便宿主机验证
3.3 进入k8s-node1节点查看目录
[root@k8s-node1 ~]# cd /data1/ #进入宿主机k8s-node1节点
[root@k8s-node1 data1]# pwd
/data1
[root@k8s-node1 data1]# ls #这是刚才两个容器中创建的目录,在宿主机上看到了,验证成功
mysql.txt nginx.txt
[root@k8s-node1 data1]#
4.对type字段说明
type: DirectoryOrCreate
DirectoryOrCreate 如果在给定路径上什么都不存在,那么将根据需要创建空目录,权限设置为 0755,具有与 kubelet 相同的组和属主信息。
5.重点说明
1. K8S hostPath存储卷运行的容器,数据被写入了被分派的宿主机上的目录下,一旦删除pod容器,数据依然在宿主机被保存了。
2. 如果重新运行该yaml文件,有可能被分派到其他的集群节点,此时之前的数据在新的节点没有;
3. 如果重新运行该yanl文件,需要指定运行在保留数据的节点上,之前的数据依然存在。
更多推荐
已为社区贡献47条内容
所有评论(0)