k8s 数据卷NFS共享卷

k8s-数据卷NFS共享卷

1. k8s数据卷NFS共享卷

  • NFS数据卷:提供对NFS挂载支持,可以自动将NFS共享路径挂载到Pod中

  • NFS:是一个主流的文件共享服务器。

  • 安装示例:

    # yum install nfs-utils -y
    # vi /etc/exports
    /ifs/kubernetes *(rw,no_root_squash)
    # mkdir -p /ifs/kubernetes
    # systemctl start nfs
    # systemctl enable nfs
    

    注:每个Node上都要安装nfs-utils包

  • NFS共享卷架构图
    k8s 数据卷NFS共享卷

  • 示例:将网站程序通过NFS数据卷共享,让所有Pod使用

  • 示例代码:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: web-nfs
    spec:
      selector:
        matchLabels:
          app: nginx-nfs
      replicas: 3
      template:
        metadata:
          labels:
            app: nginx-nfs
        spec:
          containers:
          - name: nginx-nfs
            image: nginx
            volumeMounts:
            - name: wwwroot
              mountPath: /usr/share/nginx/html
            ports:
            - containerPort: 80
          volumes:
          - name: wwwroot
            nfs:
              server: 10.100.24.85
              path: /ifs/kubernetes
    

2. 案例

2.1 安装和配置nfs

  • 安装nfs

    [root@k8s-node1 ~]# yum install nfs-utils -y
    [root@k8s-node2 ~]# yum install nfs-utils -y
    [root@k8s-node3 ~]# yum install nfs-utils -y
    
  • 用node3做本次的nfs共享磁盘

    • 修改nfs配置文件

      [root@k8s-node3 ~]# vi /etc/exports
      [root@k8s-node3 ~]# cat /etc/exports
      /ifs/kubernetes *(rw,no_root_squash)
      
    • 创建nfs共享目录

      [root@k8s-node3 ~]# mkdir -p /ifs/kubernetes
      
    • 创建index.html文件

      [root@k8s-node3 ~]# cd /ifs/kubernetes/
      [root@k8s-node3 kubernetes]# vim index.html
      [root@k8s-node3 kubernetes]# cat index.html
      <h1>hello world!</h1>
      
  • 每个node都启动并设置开机启动

    [root@k8s-node3 ~]# systemctl start nfs      #启动nfs
    [root@k8s-node3 ~]# systemctl enable nfs     # 设置开机启动
    Created symlink from /etc/systemd/system/multi-user.target.wants/nfs-server.service to /usr/lib/systemd/system/nfs-server.service.
    
    

2.2 挂载nfs盘到pod容器

  • 创建代码目录

    [root@k8s-master yaml]# mkdir -p nfs/
    [root@k8s-master yaml]# cd nfs/
    
  • 编写pod代码

    [root@k8s-master nfs]# vim nfs.yaml
    [root@k8s-master nfs]# cat nfs.yaml
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: web-nfs
    spec:
      selector:
        matchLabels:
          app: nginx-nfs
      replicas: 3
      template:
        metadata:
          labels:
            app: nginx-nfs
        spec:
          containers:
          - name: nginx-nfs
            image: nginx
            volumeMounts:
            - name: wwwroot
              mountPath: /usr/share/nginx/html
            ports:
            - containerPort: 80
          volumes:
          - name: wwwroot
            nfs:
              server: 10.100.24.85
              path: /ifs/kubernetes
    
  • 启动服务

    [root@k8s-master nfs]# kubectl apply -f  nfs.yaml
    deployment.apps/web-nfs created
    
  • 检查服务是否启动

    [root@k8s-master nfs]# kubectl get pods,service -o wide
    NAME                           READY   STATUS    RESTARTS   AGE     IP               NODE        NOMINATED NODE   READINESS GATES
    pod/configmap-demo-pod         1/1     Running   0          2d4h    10.244.107.209   k8s-node3   <none>           <none>
    pod/my-hostpath                1/1     Running   0          4h45m   10.244.107.211   k8s-node3   <none>           <none>
    pod/secret-demo-pod            1/1     Running   0          46h     10.244.107.210   k8s-node3   <none>           <none>
    pod/web-nfs-84f8d7bf8d-6mj75   1/1     Running   0          2m42s   10.244.107.212   k8s-node3   <none>           <none>
    pod/web-nfs-84f8d7bf8d-n4tpk   1/1     Running   0          2m42s   10.244.169.144   k8s-node2   <none>           <none>
    pod/web-nfs-84f8d7bf8d-qvd2z   1/1     Running   0          2m42s   10.244.36.84     k8s-node1   <none>           <none>
    
    NAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE   SELECTOR
    service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   13d   <none>
    
  • 检查内容是否存在

    [root@k8s-master nfs]# curl -I 10.244.107.212
    HTTP/1.1 200 OK
    Server: nginx/1.19.6
    Date: Mon, 28 Dec 2020 12:43:19 GMT
    Content-Type: text/html
    Content-Length: 22
    Last-Modified: Mon, 28 Dec 2020 12:17:10 GMT
    Connection: keep-alive
    ETag: "5fe9ccc6-16"
    Accept-Ranges: bytes
    
    [root@k8s-master nfs]# curl  10.244.107.212
    <h1>hello world!</h1>
    
上一篇:docker存储卷的使用


下一篇:Linux安装NFS服务器