k8s添加nfs动态绑定存储(dynamic provisioning)nfs-server-provisioner

k8s添加nfs动态绑定存储(dynamic provisioning)nfs-server-provisioner

参考:https://kubernetes.io/docs/concepts/storage/storage-classes/#local
Local volumes do not currently support dynamic provisioning, however a StorageClass should still be created to delay volume binding until Pod scheduling. This is specified by the WaitForFirstConsumer volume binding mode.

我们在裸机上安装kubernetes(私有开发环境),通常要自行设置默认storage class,常用的本地存储方式provisioner: kubernetes.io/no-provisioner不支持dynamic provisioning。
比如使用helm安装redis-cluster,就有问题,因为它使用的是动态绑定storage class

helm show values bitnami/redis-cluster

在这里插入图片描述

我们可以自行创建一个provisioner,如:nfs-server-provisioner。

先创建默认的StorageClass

kubectl create -f storageclass.yml

storageclass.yml如下

kind: StorageClass
apiVersion: storage.k8s.io/v1
metadata:
  annotations:
    storageclass.kubernetes.io/is-default-class: "true"
  name: standard
provisioner: kubernetes.io/no-provisioner
volumeBindingMode: Immediate
reclaimPolicy: Delete

使用helm安装nfs-server-provisioner

helm install storageclass-nfs stable/nfs-server-provisioner -f nfs-config.yaml

nfs-config.yaml文件如下:

persistence:
  ##开启持久存储
  enabled: true
  storageClass: "-"
  ## 存储大小30g
  size: 50Gi

storageClass:
  ##设置成默认storageclassclass
  defaultClass: true

nodeSelector:
  ##安装到哪个node上
  kubernetes.io/hostname: node1

创建pv

文件:nfs-server-pv.yaml

apiVersion: v1
kind: PersistentVolume
metadata:
  name: data-nfs-server-provisioner-0
spec:
  capacity:
    storage: 50Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    ## 绑定在node上的位置
    path: /data/k8s/volumes/data-nfs-server-provisioner-0
  claimRef:
    namespace: default
    ## 自动生成的pvc名字
    name: data-storageclass-nfs-nfs-server-provisioner-0

创建

k create -f nfs-server-pv.yaml

三、每台机器上都要装nfs

yum -y install nfs-utils 
systemctl restart rpcbind && systemctl enable rpcbind 
systemctl restart nfs && systemctl enable nfs

参考:
helm安装
https://blog.csdn.net/evane1890/article/details/112673261

常见问题

没有安装nfs

mount: 文件系统类型错误、选项错误、10.96.169.147:/export/pvc-5bf2207d-0563-4757-88db-eaca90619a83 上有坏超级块、
缺少代码页或助手程序,或其他错误
(对某些文件系统(如 nfs、cifs) 您可能需要
一款 /sbin/mount.<类型> 助手程序)

安装参考

k8s安装elasticsearch并使用持久存储
K8s上运行Redis集群指南.md

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100347.html原文链接:https://javaforall.net

(0)
上一篇 2021年5月14日 下午7:00
下一篇 2021年5月14日 下午8:00


相关推荐

  • Oracle运算符

    Oracle运算符

    2021年8月15日
    50
  • web实现QQ第三方登录[通俗易懂]

    web实现QQ第三方登录[通俗易懂]开放平台-web实现QQ第三方登录应用场景web应用通过QQ登录授权实现第三方登录。操作步骤1注册成为QQ互联平台开发者,http://connect.qq.com/2准备一个可访问的域名,

    2022年8月2日
    9
  • 网络安全

    网络安全

    2026年3月14日
    3
  • 传智健康day06 移动端开发-体检预约

    传智健康day06 移动端开发-体检预约1.移动端开发1.1移动端开发方式随着移动互联网的兴起和手机的普及,目前移动端应用变得愈发重要,成为了各个商家的必争之地。例如,我们可以使用手机购物、支付、打车、玩游戏、订酒店、购票等,以前只能通过PC端完成的事情,现在通过手机都能够实现,而且更加方便,而这些都需要移动端开发进行支持,那如何进行移动端开发呢?移动端开发主要有三种方式:1、基于手机API开发(原生APP)2、基于手机浏览器开发(移动web)3、混合开发(混合APP)1.1.1基于手机API开发手机端使用手

    2022年6月24日
    42
  • Maven的GroupID和ArtifactID的含义「建议收藏」

    标签:目的   left   就会   定义   平时   包名   项目   rep   depend   groupID:是项目组织唯一的标识符,实际对应Java的包的结构,是main目录里Java的目录结构。artifactID:是项目的唯一标识符,实际对应项目的名称,就是项目根目录的名称。 1.基础掌握&lt;groupId&gt;com.yucong.commonma…

    2022年4月14日
    232
  • android 创建数组

    android 创建数组一:privateString[]data=newString[]{“Hello”,”jike”,”world”};二:创建数组对象:privateCellData[]data=newCellData[]{newCellData(“jike”,”world”),newCellData(“title”,”content”)};publiccl…

    2022年6月1日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号