存储组件 nfs-subdir-external-provisioner 是一个存储资源自动调配器,它可用将现有的 NFS 服务器通过持久卷声明来支持 Kubernetes 持久卷的动态分配。此组件是对 nfs-client-provisioner 的扩展,nfs-client-provisioner 已经不提供更新,且 nfs-client-provisionerGithub仓库已经迁移到 nfs-subdir-external-provisioner 的仓库。

nfs-subdir-external-provisioner官方Github地址

k8s版本:v1.23.1

准备工作:
  • 搭建好NFS服务;
  • 安装好helm

使用helm安装:
  1. 使用命令行进行安装:

    #添加helm源
    helm repo add nfs-subdir-external-provisioner https://kubernetes-sigs.github.io/nfs-subdir-external-provisioner #创建个namespace(可选,主要是为了查看资源方便)
    kubectl create ns nfs-sc-default #使用helm安装(10.1.129.86为NFS地址,/data/nfs-data为共享的目录)
    helm install nfs-subdir-external-provisioner nfs-subdir-external-provisioner/nfs-subdir-external-provisioner \
    --set storageClass.name=nfs-sc-default #指定sc的名字
    --set nfs.server=10.1.129.86 \ #指定nfs地址
    --set nfs.path=/data/nfs-data \ #指定nfs的共享目录
    --set storageClass.defaultClass=true \ #指定为默认sc
    -n nfs-sc-default #指定命名空间 #查看创建的sc
    kubectl get sc
  2. 使用values.yaml进行安装:

    #下载chart
    helm pull nfs-subdir-external-provisioner/nfs-subdir-external-provisioner #解压后可以看到values.yaml
    cat values.yaml | egrep -v '#|^$' ###########
    replicaCount: 1
    strategyType: Recreate
    image:
    repository: k8s.gcr.io/sig-storage/nfs-subdir-external-provisioner
    tag: v4.0.2
    pullPolicy: IfNotPresent
    imagePullSecrets: []
    nfs:
    server: 10.1.129.86 #指定nfs地址
    path: /data/nfs-data #指定nfs的共享目录
    mountOptions:
    volumeName: nfs-subdir-external-provisioner-root
    reclaimPolicy: Retain
    storageClass:
    create: true
    defaultClass: true #指定为默认sc
    name: nfs-sc-default #指定sc的名字
    allowVolumeExpansion: true
    reclaimPolicy: Delete
    archiveOnDelete: true
    onDelete:
    pathPattern:
    accessModes: ReadWriteOnce
    annotations: {}
    leaderElection:
    enabled: true
    rbac:
    create: true
    podSecurityPolicy:
    enabled: false
    podAnnotations: {}
    podSecurityContext: {}
    securityContext: {}
    serviceAccount:
    create: true
    annotations: {}
    name:
    resources: {}
    nodeSelector: {}
    tolerations: []
    affinity: {}
    labels: {}
    ########### #就修改了上面4处参数后使用values.yaml文件进行安装
    helm install nfs-subdir-external-provisioner \
    nfs-subdir-external-provisioner/nfs-subdir-external-provisioner \
    -f values.yaml \
    -n nfs-sc-default #查看创建的sc
    kubectl get sc

测试:
  1. 创建pvc测试:

    先创建个test-pvc.yaml,在这个yaml文件里我们没有特意指定使用哪个sc,是因为之前创建的sc是默认的sc,如果没有指定默认sc,需要在这个文件里指定使用哪个sc

    cat test-pvc.yaml
    
    ##########
    kind: PersistentVolumeClaim
    apiVersion: v1
    metadata:
    name: test-pvc
    # storageClassName: nfs-sc-default #指定sc名字,如果之前设定nfs-sc-default为默认sc可不用写这行指定
    spec:
    accessModes:
    - ReadWriteMany
    resources:
    requests:
    storage: 1Mi
    ########## #创建pvc
    kubectl apply -f test-pvc.yaml -n nfs-sc-default #查看pvc
    kubectl get pvc -n nfs-sc-default

    查看pv,如图第二个为sc创建的pv,名字为随机,并已经与test-pvc绑定了:

  2. 创建pod测试:

    创建test-pod.yaml文件,在这个yaml文件里我们只指定了busybox文件创建了个SUCCESS文件,绑定的volume里指定的是之前创建的test-pvc

    cat test-pod.yaml
    
    #########
    kind: Pod
    apiVersion: v1
    metadata:
    name: test-pod
    spec:
    containers:
    - name: test-pod
    image: busybox:latest
    command:
    - "/bin/sh"
    args:
    - "-c"
    - "touch /mnt/SUCCESS && exit 0 || exit 1"
    volumeMounts:
    - name: nfs-pvc
    mountPath: "/mnt"
    restartPolicy: "Never"
    volumes:
    - name: nfs-pvc
    persistentVolumeClaim:
    claimName: test-pvc
    ######### #创建测试pod
    kubectl apply -f test-pod.yaml -n nfs-sc-default #查看pod已经显示创建成功了
    kubectl get pod -n nfs-sc-default
  3. 查看NFS目录里创建的文件:

    可以看见SUCCESS文件创建成功,并且可以看出命名目录的规则为namespace名称-pvc名称-pv名称PV 名称是随机字符串,所以 每次只要不删除PVC,那么Kubernetes中的与存储绑定将不会丢失,要是删除PVC也就意味着删除了绑定的文件夹,下次就算重新创建相同名称的PVC,生成的文件夹名称也不会一致,因为PV 名是随机生成的字符串,而文件夹命名又跟PV 有关,所以删除PVC需谨慎。

  4. 删除相关测试的资源:

    kubectl delete -f test-pod.yaml  -n nfs-sc-default
    kubectl delete -f test-pvc.yaml -n nfs-sc-default

使用helm安装nfs-subdir-external-provisioner实现动态创建存储的更多相关文章

  1. Helm 安装Kafka

    helm镜像库配置 helm repo add stable http://mirror.azure.cn/kubernetes/charts helm repo add incubator http ...

  2. 使用helm安装jenkin和gitlab

    一.使用服务介绍 存储: 阿里云NAS k8s网络插件: calico k8s版本: 1.15.2 二.helm安装 https://www.cnblogs.com/zhangb8042/p/1020 ...

  3. Linux下安装nfs服务器

    1. 安装nfs服务 $sudo apt-get install nfs-kernel-server portmap 2. 在配置文件/etc/exports中添加以下内容/home/jxhui/nf ...

  4. CentOS7 安装NFS SSH免密码登陆

    配置5台虚拟机 ip为192.168.1.160 - 164,使用160作为共享服务器 使用yum安装nfs 以及rpcbind,有很多文章介绍,这里不再赘述 一.启动服务 1.启动rpcbind s ...

  5. Linux centos 7 安装NFS服务

    NFS服务简介:NFS是Network File System的缩写,即网络文件系统.客户端通过挂载的方式将NFS服务器端共享的数据目录挂载到本地目录下.---主要功能指的是共享文件 为什么要安装NF ...

  6. kubernetes包管理工具Helm安装

    helm官方建议使用tls,首先生成证书. openssl genrsa -out ca.key.pem openssl req -key ca.key.pem -new -x509 -days -s ...

  7. kubernetes(k8s) helm安装kafka、zookeeper

    通过helm在k8s上部署kafka.zookeeper 通过helm方法安装 k8s上安装kafka,可以使用helm,将kafka作为一个应用安装.当然这首先要你的k8s支持使用helm安装.he ...

  8. centos7安装NFS

    在服务器上安装nfs服务,并将该服务器的/data目录进行共享. 服务端配置 安装nfs组件,并检查安装状态 yum install nfs-utils rpcbindrpm -qa nfs-util ...

  9. Ubuntu下安装nfs服务器

    安装 NFS 软件包在 ubuntu 终端输入下面命令安装 NFS 服务器:vmuser@Linux-host: ~$ sudo apt-get install nfs-kernel-server # ...

随机推荐

  1. 将Cesium Tools用于更好的构建管理

    Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ Cesium技术正在给建筑业带来革命性的变化.我们与 partn ...

  2. golang中结构体标签在json中的应用

    package main import ( "encoding/json" "fmt" "reflect" ) type Movie str ...

  3. 集合框架-LinkedHashSet集合(有序唯一)

    1 package cn.itcast.p4.hashset.demo; 2 3 import java.util.HashSet; 4 import java.util.Iterator; 5 im ...

  4. Github基于Web的编辑器

    在 GitHub 存储库中使用基于 Web 的编辑器来创建和提交代码更改. 关于 GitHub 基于 Web 的编辑器 基于 Web 的编辑器引入了全新的轻量级编辑体验,可完全在您的浏览器中运行.使用 ...

  5. Redis入门及环境搭建

    一:Redis简介 Redis(Remote Dictionary Server 远程字典服务)是一个开源的(BSD许可的)内存数据结构存储,用作数据库.高速缓存和消息队列代理. Redis提供五大基 ...

  6. 『无为则无心』Python函数 — 38、Python中的异常

    目录 1.异常概念 2.了解异常 3.异常的写法 (1)语法 (2)快速体验 (3)捕获指定异常 (4)异常中的else (5)异常中的finally (6)总结 1.异常概念 定义:程序在运行过程当 ...

  7. 30分钟使用Docsify+Github Pages搭建个人博客

    前言 现如今网上有许多完善的博客平台,如博客园.掘金.思否.知乎等.有人会说为什么现在网上有这么多成熟的博客平台,你还要浪费时间搭建一个自己的博客平台呢?首先我相信每一个程序员都会想要拥有一个属于自己 ...

  8. Vue中的发布订阅分析(Vue2/3中的 emit 实现)

    Vue中的发布订阅模式分析 模块:instanceEventEmiiter.ts(在下方有简单实现和解析) 在Vue3中,已经取消了对这个模块的引用,故而不再支持 $on.$off.$once相关的方 ...

  9. ApacheCN C/C++ 译文集 20211201 更新

    笨办法学C 中文版 前言 导言:C的笛卡尔之梦 练习0:准备 练习1:启用编译器 练习2:用Make来代替Python 练习3:格式化输出 练习4:Valgrind 介绍 练习5:一个C程序的结构 练 ...

  10. SP19149 INS14H - Virus Revisited

    可以发现,如果一个整体一起考虑是不能找到一个合适的状态来描述这个情形的. 因此可以考虑寻找整体的反面,也就是将每个维度分开考虑. 不难发现每个维度本质上是一样的,因此不需要考虑不同维度之间的区别. 那 ...