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文件,需要指定运行在保留数据的节点上,之前的数据依然存在。

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐