微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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共享卷架构图

    image

  • 示例:将网站程序通过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>
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐