zoukankan      html  css  js  c++  java
  • k8s创建使用nfs的StorageClass

    在k8s中pod需要持久化数据就需要挂卷,一般会使用pvc,这样就需要先有StorageClass,记录一下如何创建使用NFS共享存储的StorageClass

            之前已经搭建了一个NFS共享存储了,参考 搭建NFS共享存储

      用下面命令在k8s节点上安装NFS组件,可以用 showmount -e 查看共享存储,可以看到在10.110.30.216的主机上共享了/nfs-data 目录

    yum -y install nfs-utils;
    systemctl enable rpcbind;
    systemctl start rpcbind;

    1、手动创建一个pv和pvc测试一下nfs是否可用,将下面代码保存到文件后执行create安装命令 kubectl create -f pv-pvc.yaml

    ---
    apiVersion: v1
    kind: PersistentVolume
    metadata:
      name: pv-test
    spec:
      capacity:
        storage: 1Gi
      accessModes:
        - ReadWriteOnce
      persistentVolumeReclaimPolicy: Recycle
      nfs:
        path: /nfs-data
        server: 10.110.30.216
    
    ---
    kind: PersistentVolumeClaim
    apiVersion: v1
    metadata:
      name: pvc-test
    spec:
      accessModes:
        - ReadWriteOnce
      resources:
        requests:
          storage: 100Mi

     创建之后查看绑定信息,可以看到已经成功绑定了,说明k8s中可以使用这个NFS,可以继续下一步开始创建StorageClass了。

    2、创建StorageClass参考github上的文档,nfs-client是一个自动预配置程序,它使用已有的NFS服务器来支持Kubernetes卷的动态预设置,官方的方法是通过安装一个nfs-client-provisioner,参考【nfs-client配置说明】,安装所用的yaml文件在deploy文件夹中 https://github.com/kubernetes-incubator/external-storage/tree/master/nfs-client/deploy 但是还是需要根据自己情况对文件做一些修改,默认使用的镜像是quay.io/external_storage/nfs-client-provisioner:latest,这个地址有可能无法访问,如果遇到无法访问的的情况可以试试其他的镜像仓库,例如去阿里云的仓库找找。

    另外还提供了一个heml的chart包,地址 【nfs-client-provisioner的HELM包】,我这里集群已经安装helm了,先尝试用用这个方法。

    3、修改chart包,将values.yaml中的部分参数值修改成实际值

    nfs:
      server: 10.110.30.216
      path: /nfs-data
      mountOptions:
    
      reclaimPolicy: Retain

    4、安装

    helm install --name nfs-client-provisioner nfs-client-provisioner/

     可以看到StorageClass已经创建出来了,下面测试一下是否可用,安装下面的nginx测试,注意storageClassName就是我们上面创建的StorageClass的名称

    # nginx.yaml
    
    apiVersion: apps/v1
    kind: StatefulSet
    metadata:
      name: my-nginx-demo
      labels:
        app.kubernetes.io/name: my-nginx-demo
        app.kubernetes.io/version: "1.0"
    spec:
      replicas: 1
      serviceName: my-nginx-demo-svc
      selector:
        matchLabels:
          app.kubernetes.io/name: my-nginx-demo
      template:
        metadata:
          labels:
            app.kubernetes.io/name: my-nginx-demo
        spec:
          restartPolicy: Always
          containers:
            - name: my-nginx-demo
              image: "nginx:1.17.9"
              imagePullPolicy: IfNotPresent
              ports:
                - name: http
                  containerPort: 80
                  protocol: TCP
              livenessProbe:
                httpGet:
                  path: /
                  port: http
              readinessProbe:
                httpGet:
                  path: /
                  port: http
              volumeMounts:
              - mountPath: "/usr/share/nginx/html"
                name: html
                
      volumeClaimTemplates:
        - metadata:
            name: html
          spec:
            accessModes:
              - ReadWriteOnce
            resources:
              requests:
                storage: 1Gi
            storageClassName: nfs-client
    
    ---
    apiVersion: v1
    kind: Service
    metadata:
      name: my-nginx-demo-svc
      labels:
        app.kubernetes.io/name: my-nginx-demo
        app.kubernetes.io/version: "1.0"
    spec:
      # type: ClusterIP
      # type: LoadBalancer
      type: NodePort
      ports:
        - port: 80
          targetPort: http
          protocol: TCP
          name: http
      selector:
        app.kubernetes.io/name: my-nginx-demo

    kubectl create -f nginx.yaml 安装,然后查看pv、pvc以及pod可以看到都创建成功了,(pod的状态先忽略吧,现在是因为挂载目录为是nginx的文件目录,应该是现在目录为空导致启动异常,暂时先不处理这个了),然后我们看NFS服务端的工项目录,下面也创建了一个文件夹,对应着上面的pv

     我们在nfs共享目录的文件夹里创建个测试文件,看看容器内是否生效

    vi index.html
    然后输入下面内容后保存
    <html><body><h1>Test Page!</h1></body></html>

     创建了文件之后,等一会pod的状态也正常了,通过service访问一下服务,也显示正常了

     通过上面页面也可以看出来,pod挂的卷确实映射到了NFS服务共享出来的目录中了

    5、上面是通过helm模板的方式安装的,如果没有helm,可以手动执行,直接参考 https://github.com/kubernetes-incubator/external-storage/tree/master/nfs-client 页面中的描述,按照实际情况修改 deploy 文件夹中的yaml文件,然后执行安装就可以,修改的内容主要就是namespace

  • 相关阅读:
    ibatis的优缺点及可行性分析
    NHibernate优点和缺点:
    IbatisNet的介绍和使用
    bat(续七)-for语句(循环结构)
    bat(续五)-获取批处理文件所在路径
    Shell函数参数
    Shell函数:Shell函数返回值、删除函数、在终端调用函数
    Shell break和continue命令
    Shell until循环
    Shell while循环
  • 原文地址:https://www.cnblogs.com/yanh0606/p/12658641.html
Copyright © 2011-2022 走看看