zoukankan      html  css  js  c++  java
  • 第8关 k8s架构师课程之持久化存储StorageClass

    https://www.toutiao.com/a6941342788319478304/?log_from=078a468921484_1630843405252

    https://www.bilibili.com/video/BV1ji4y1P7dX?spm_id_from=333.999.0.0

    StorageClass

    PV是运维人员来创建的,开发操作PVC,可是大规模集群中可能会有很多PV,如果这些PV都需要运维手动来处理这也是一件很繁琐的事情,所以就有了动态供给概念,也就是Dynamic Provisioning。而我们上面的创建的PV都是静态供给方式,也就是Static Provisioning。而动态供给的关键就是StorageClass,它的作用就是创建PV模板。

    创建StorageClass里面需要定义PV属性比如存储类型、大小等;另外创建这种PV需要用到存储插件。最终效果是,用户提交PVC,里面指定存储类型,如果符合我们定义的StorageClass,则会为其自动创建PV并进行绑定。

    我们这里演示一下NFS的动态PV创建

    kubernetes本身支持的动态PV创建不包括nfs,所以需要使用额外插件实现。nfs-client

    我这里就按照网站的例子来创建,里面的内容毫无修改,当然你需要自己准备NFS服务器。由于用于提供动态创建PV的程序是运行在POD中,所以你需要保证你的Kubernetes节点到NFS的网络通畅,我这里就在我的Kubernetes集群的某个节点上建立的NFS服务。下面是PVC文件

    Kubernetes NFS-Client Provisioner创建Storageclass。

    假设我们已经搭建了一个外部的NFS-server,根据官方的文档,我们首先需要部署:

    • nfs-client-provisioner
    • nfs-client rbac
    • storageclass

    nfs-client-provisioner 是一个Kubernetes的简易NFS的外部provisioner,本身不提供NFS,需要现有的NFS服务器提供存储。

     nfs-client-provisioner 是一个自动配置程序,它使用配置好的 NFS Server 通过持久卷声明动态配置 Kubernetes 持久化存储。

    本文来源:码农网
    本文链接:https://www.codercto.com/a/71634.html

    nfs-client-provisioner 主要分为两部分:

    • 在 NFS 共享目录建立 Volume
    • 在 Kubernetes 创建持久化存储卷 PV 并与 Volume 做关联

    StorageClass 负责建立 PVC 并且与 nfs-client-provisioner 通讯,建立 PVC 和 PV 的连接。

    此外还需要创建 ServiceAccount 来保障 nfs-client-provisioner 在 Kubernetes 有足够的权限运行。 nfs-client-provisioner是一个pod来运行,此外还需要创建 ServiceAccount 来保障 nfs-client-provisioner 在 Kubernetes 有足够的权限运行。配置 nfs-client-provisioner 之前,首先要定义一个 Service Account 使用 Kubernetes 中的 RBAC 机制进行授权。有了相应的权限 nfs-client-provisioner 可以对 StorageClass 、 PersistentVolumeClaim 进行操作(Role + RoleBinding + ClusterRole + ClusterRoleBinding)。

    参考:

    StorageClass

    我这是直接拿生产中用的实例来作演示,利用nfs-client-provisioner来生成一个基于nfs的StorageClass,部署配置yaml配置如下,保持为nfs-sc.yaml:

    apiVersion: v1
    kind: ServiceAccount
    metadata:
      name: nfs-client-provisioner
      namespace: kube-system
    
    ---
    kind: ClusterRole
    apiVersion: rbac.authorization.k8s.io/v1
    metadata:
      name: nfs-client-provisioner-runner
    rules:
      - apiGroups: [""]
        resources: ["persistentvolumes"]
        verbs: ["get", "list", "watch", "create", "delete"]
      - apiGroups: [""]
        resources: ["persistentvolumeclaims"]
        verbs: ["get", "list", "watch", "update"]
      - apiGroups: ["storage.k8s.io"]
        resources: ["storageclasses"]
        verbs: ["get", "list", "watch"]
      - apiGroups: [""]
        resources: ["events"]
        verbs: ["list", "watch", "create", "update", "patch"]
      - apiGroups: [""]
        resources: ["endpoints"]
        verbs: ["get", "list", "watch", "create", "update", "patch"]
    
    ---
    kind: ClusterRoleBinding
    apiVersion: rbac.authorization.k8s.io/v1
    metadata:
      name: run-nfs-client-provisioner
    subjects:
      - kind: ServiceAccount
        name: nfs-client-provisioner
        namespace: kube-system 
    roleRef:
      kind: ClusterRole
      name: nfs-client-provisioner-runner
      apiGroup: rbac.authorization.k8s.io
    
    ---
    kind: Deployment
    apiVersion: apps/v1
    metadata:
      name: nfs-provisioner-01
      namespace: kube-system
    spec:
      replicas: 1
      strategy:
        type: Recreate
      selector:
        matchLabels:
          app: nfs-provisioner-01
      template:
        metadata:
          labels:
            app: nfs-provisioner-01
        spec:
          serviceAccountName: nfs-client-provisioner
          containers:
            - name: nfs-client-provisioner
              image: jmgao1983/nfs-client-provisioner:latest
              imagePullPolicy: IfNotPresent
              volumeMounts:
                - name: nfs-client-root
                  mountPath: /persistentvolumes
              env:
                - name: PROVISIONER_NAME
                  value: nfs-provisioner-01  # 此处供应者名字供storageclass调用
                - name: NFS_SERVER
                  value: 10.0.1.201   # 填入NFS的地址
                - name: NFS_PATH
                  value: /nfs_dir   # 填入NFS挂载的目录
          volumes:
            - name: nfs-client-root
              nfs:
                server: 10.0.1.201   # 填入NFS的地址
                path: /nfs_dir   # 填入NFS挂载的目录
    
    ---
    apiVersion: storage.k8s.io/v1
    kind: StorageClass
    metadata:
      name: nfs-boge
    provisioner: nfs-provisioner-01
    # Supported policies: Delete、 Retain , default is Delete
    reclaimPolicy: Retain

    上面有几个关键的点:让创建的nfs-client-provisioner容器具有访问k8s组件的权限 serviceAccountName: nfs-client-provisioner

    上面的nfs的地址和安装路径不要写错了

    开始创建这个StorageClass:

    # kubectl apply -f nfs-sc.yaml 
    serviceaccount/nfs-client-provisioner created
    clusterrole.rbac.authorization.k8s.io/nfs-client-provisioner-runner created
    clusterrolebinding.rbac.authorization.k8s.io/run-nfs-client-provisioner created
    deployment.apps/nfs-provisioner-01 created
      orageclass.storage.k8s.io/nfs-boge created
    
    # 注意这个是在放kube-system的namespace下面,这里面放置一些偏系统类的服务
    # kubectl -n kube-system get pod -w
    NAME                                       READY   STATUS              RESTARTS   AGE
    calico-kube-controllers-7fdc86d8ff-dpdm5   1/1     Running             1          24h
    calico-node-8jcp5                          1/1     Running             1          24h
    calico-node-m92rn                          1/1     Running             1          24h
    calico-node-xg5n4                          1/1     Running             1          24h
    calico-node-xrfqq                          1/1     Running             1          24h
    coredns-d9b6857b5-5zwgf                    1/1     Running             1          24h
    metrics-server-869ffc99cd-wfj44            1/1     Running             2          24h
    nfs-provisioner-01-5db96d9cc9-qxlgk        0/1     ContainerCreating   0          9s
    nfs-provisioner-01-5db96d9cc9-qxlgk        1/1     Running             0          21s
    

     我们来基于StorageClass创建一个pvc,看看动态生成的pv是什么效果:

    # vim pvc-sc.yaml 
    kind: PersistentVolumeClaim
    apiVersion: v1
    metadata:
      name: pvc-sc
    spec:
      storageClassName: nfs-boge
      accessModes:
        - ReadWriteMany
      resources:
        requests:
          storage: 1Mi
    # kubectl  apply -f pvc-sc.yaml 
    persistentvolumeclaim/pvc-sc created
    
    # kubectl  get pvc
    NAME     STATUS   VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS   AGE
    pvc-sc   Bound    pvc-63eee4c7-90fd-4c7e-abf9-d803c3204623   1Mi        RWX            nfs-boge       3s
    pvc1     Bound    pv1                                        1Gi        RWO            nfs            24m
    
    # kubectl  get pv
    NAME                                       CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS   CLAIM            STORAGECLASS   REASON   AGE
    pv1                                        1Gi        RWO            Recycle          Bound    default/pvc1     nfs                     49m
    pvc-63eee4c7-90fd-4c7e-abf9-d803c3204623   1Mi        RWX            Retain           Bound    default/pvc-sc   nfs-boge                7s

    我们修改下nginx的yaml配置,将pvc的名称换成上面的pvc-sc:

    # vim nginx.yaml 
    ---
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      labels:
        app: nginx
      name: nginx
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: nginx
      template:
        metadata:
          labels:
            app: nginx
        spec:
          containers:
          - image: nginx
            name: nginx
            volumeMounts:    # 我们这里将nginx容器默认的页面目录挂载
              - name: html-files
                mountPath: "/usr/share/nginx/html"
          volumes:
            - name: html-files
              persistentVolumeClaim:
                claimName: pvc-sc
                
                
    # kubectl apply -f nginx.yaml 
    service/nginx unchanged
    deployment.apps/nginx configured
    
    # 这里注意下,因为是动态生成的pv,所以它的目录基于是一串随机字符串生成的,这时我们直接进到pod内来创建访问页面
    # kubectl exec -it nginx-57cdc6d9b4-n497g -- bash
    root@nginx-57cdc6d9b4-n497g:/# echo 'storageClass used' > /usr/share/nginx/html/index.html
    root@nginx-57cdc6d9b4-n497g:/# exit
    
    # curl 10.68.238.54                              
    storageClass used
    
    # 我们看下NFS挂载的目录
    # ll /nfs_dir/
    total 0
    drwxrwxrwx 2 root root 24 Nov 27 17:52 default-pvc-sc-pvc-63eee4c7-90fd-4c7e-abf9-d803c3204623
    drwxr-xr-x 2 root root  6 Nov 27 17:25 pv1
    
    

     

    举报
     






  • 相关阅读:
    docker gitlab and gitlab api
    service mesh,linkerd,sidecar,apigateway
    FIS3
    various system release [online]
    certification on windows and
    postman_
    macbook ios recovery and mount hfs+ journal and revert
    distribution system index
    登录科普(一)CAS与Oauth
    sonar,jiar,xray,jenkins[cli] [sudoers]
  • 原文地址:https://www.cnblogs.com/kebibuluan/p/15230784.html
Copyright © 2011-2022 走看看