赞
踩
hostPath Volume 是指 Pod 挂载宿主机上的目录或文件。 hostPath Volume 使得容器可以使用宿主机的文件系统进行存储 , hostpath (宿主机路径):节点级别的存储卷,在 pod 被删除,这个存储卷还是存在的,不会被删除,所以只要同一个 pod 被调度到同一个节点上来,在 pod 被删除重新被调度到这个节点之后,对应的数据依然是存在的。
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.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]#
type: DirectoryOrCreate
DirectoryOrCreate 如果在给定路径上什么都不存在,那么将根据需要创建空目录,权限设置为 0755,具有与 kubelet 相同的组和属主信息。
1. K8S hostPath存储卷运行的容器,数据被写入了被分派的宿主机上的目录下,一旦删除pod容器,数据依然在宿主机被保存了。
2. 如果重新运行该yaml文件,有可能被分派到其他的集群节点,此时之前的数据在新的节点没有;
3. 如果重新运行该yanl文件,需要指定运行在保留数据的节点上,之前的数据依然存在。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。