k8s笔记13--配置nfs-client-provisioner

2024-05-30 23:48

本文主要是介绍k8s笔记13--配置nfs-client-provisioner,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

k8s笔记13--配置nfs-client-provisioner

  • 1 介绍
  • 2 部署测试
    • 2.1 使用helm
    • 2.2 使用案例
  • 3 注意事项
  • 4 说明

1 介绍

NFS 客户端配置器是 Kubernetes 的自动配置器,它使用已经配置的 NFS 服务器,自动创建持久卷,从而为其它应用提供持久化存储。自动创建的持久卷在nfs的根目录下存储形式为:${namespace}-${pvcName}-${pvName}。

本文通过helm部署nfs-client,并为minio 提供持久化存储。后续会在此处持续更新 nfs-client-provisioner 相关的使用方式和注意事项。

2 部署测试

2.1 使用helm

  1. 部署nfs-client
    详细参数可以参考 githu stable/nfs-client-provisioner
    搭建nfs服务器:
    # cat /etc/exports |grep data
    /data/nfs *(insecure,rw,sync,fsid=0,crossmnt,no_subtree_check)
    /etc/init.d/nfs-kernel-server restart
    # 部署nfs-client
    helm install nfs-client stable/nfs-client-provisioner --set nfs.server=192.168.1.4 --set nfs.path=/data/nfs或者在https://github.com/helm/charts 下载repo文件,解压出 stable/nfs-client-provisioner目录
    helm install nfs-client nfs-client-provisioner/ --set nfs.server=192.168.1.4 --set nfs.path=/data/nfs安装成功后可以正常get sc:
    $ kubectl get sc
    NAME         PROVISIONER                                       RECLAIMPOLICY   VOLUMEBINDINGMODE   ALLOWVOLUMEEXPANSION   AGE
    nfs-client   cluster.local/nfs-client-nfs-client-provisioner   Delete          Immediate           true                   11m
    
  2. 测试
    笔者使用新建的nfs-client 为mino分配动态存储,minio 部署方法见博文:minio笔记3–基于k8s搭建minio集群
    nfs-client 和 minio 部署成功后,可以看到已经有了SC nfs-client 且动态生成了pvc,如下图:
    sc:
    在这里插入图片描述
    pvc:
    在这里插入图片描述
    pv:
    在这里插入图片描述
    在物理机的nfs 目录下也生成了对应的存储目录,如下图所示:
    在这里插入图片描述
    综上,nfs-client 已经成功部署,且达到了应有的效果。

2.2 使用案例

本案例中基于nfs-client创建pvc, 然后将其挂载到busybox中。

vim pvc.yaml 
kind: PersistentVolumeClaim
apiVersion: v1
metadata:name: test-claim
spec:storageClassName: nfs-clientaccessModes:- ReadWriteOnceresources:requests:storage: 102Mivim busybox.yaml 
apiVersion: apps/v1
kind: Deployment
metadata:creationTimestamp: nulllabels:app: busybox-pvcname: busybox-pvc
spec:replicas: 1selector:matchLabels:app: busybox-pvcstrategy: {}template:metadata:creationTimestamp: nulllabels:app: busybox-pvcspec:containers:- image: busybox:1.31name: busyboxcommand: [sh, -c, "sleep infinity"]volumeMounts:- name: data-nfsmountPath: /data-nfsresources: {}volumes:- name: data-nfspersistentVolumeClaim:claimName: test-claim
status: {}# kubectl apply -f pvc.yaml
# kubectl apply -f busybox.yaml

在busybox 终端中写入几个数据文件,可以发现已经正常挂载了nfs目录:
在这里插入图片描述

3 注意事项

  1. to add

4 说明

软件环境:
k8s 版本: 1.19.4
nfs-client-provisioner chart版本:stable/nfs-client-provisioner:1.2.11
参考文档:
1 github external-storage/tree/master/nfs-client
2 github stable/nfs-client-provisioner
3 k8s中创建nfs存储类(公共盘)

这篇关于k8s笔记13--配置nfs-client-provisioner的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017089

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Debian系和Redhat系防火墙配置方式

《Debian系和Redhat系防火墙配置方式》文章对比了Debian系UFW和Redhat系Firewalld防火墙的安装、启用禁用、端口管理、规则查看及注意事项,强调SSH端口需开放、规则持久化,... 目录Debian系UFW防火墙1. 安装2. 启用与禁用3. 基本命令4. 注意事项5. 示例配置R

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Redis MCP 安装与配置指南

《RedisMCP安装与配置指南》本文将详细介绍如何安装和配置RedisMCP,包括快速启动、源码安装、Docker安装、以及相关的配置参数和环境变量设置,感兴趣的朋友一起看看吧... 目录一、Redis MCP 简介二、安www.chinasem.cn装 Redis MCP 服务2.1 快速启动(推荐)2.

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例