当前位置: 首页 > news >正文

k8s v1.26 实战csi-nfs 部署

一 前言

使用自开发的一键k8s基础环境部署后,存储需要解决,就是测试环境故选择nfs比较简单,翻阅很多网上资料感觉都不是很全面,结合网上资料折腾了一天,总算是完成了csi-nfs部署。其实之前也部署过,经过一段时间就遗忘了,这次决定把完整步骤记录下来,方便以后查阅,同时也方便其他和我一样需要部署csi-nfs的人作为参考。

二 csi-nfs 概念

  csi-nfs 就是为k8s 提供nfs存储实现数据持久化的一套接口插件,我这么理解,网上有很专业的说法,记不住反正。总之就是你想使用nfs作为k8s的数据持久化存储,你就选用csi-nfs 就对了。

三 NFS服务

  既然使用NFS作为存储,那么就需要先搞个NFS服务对吧,找一台机器(centos)安装nfs服务

yum install -y nfs-utils rpcbind
mkdir -p /data/nfs
chmod -R 755 /data/nfs编辑 vim /etc/exports/data/nfs 192.168.3.0/24 (rw,sync,no_root_squash)
保存退出exportfs -ra
exportfs -v启动nfs服务
systemctl start rpcbind
systemctl start nfs-server
设置开机启动nfs服务
systemctl enable rpcbind
systemctl enable nfs-server

以上是nfs服务安装,需要详细安装的请网上查阅,这个nfs服务安装网上资料比较全,不再赘述。

四 k8s环境部署csi-nfs

k8s中部署csi-nfs 是重点,首先需要去csi-nfs 仓库下载相关资料 地址如下

https://github.com/kubernetes-csi/csi-driver-nfs

参考上图直接下载就行了

下载后解压到系统任意目录下。

解压后 目录是csi-driver-nfs-master 

cd 切换到csi-driver-nfs-master 目录下面

由于镜像源都是国外的下载不了,故我们进行一个批量镜像源替换,统一替换到阿里云源就行

使用grep命令查看镜像情况,注:下图是我替换过的。

[root@localhost csi-driver-nfs-master]# grep image deploy/*.yaml
deploy/csi-nfs-controller.yaml:          image: registry.aliyuncs.com/google_containers/csi-provisioner:v5.2.0
deploy/csi-nfs-controller.yaml:          image: registry.aliyuncs.com/google_containers/csi-snapshotter:v8.2.1
deploy/csi-nfs-controller.yaml:          imagePullPolicy: IfNotPresent
deploy/csi-nfs-controller.yaml:          image: registry.aliyuncs.com/google_containers/livenessprobe:v2.15.0
deploy/csi-nfs-controller.yaml:          image: registry.cn-hangzhou.aliyuncs.com/image-storage/nfspluginnfsplugin:v4.6.0
deploy/csi-nfs-controller.yaml:          imagePullPolicy: IfNotPresent
deploy/csi-nfs-node.yaml:          image: registry.aliyuncs.com/google_containers/livenessprobe:v2.15.0
deploy/csi-nfs-node.yaml:          image: registry.aliyuncs.com/google_containers/csi-node-driver-registrar:v2.13.0
deploy/csi-nfs-node.yaml:          image: registry.cn-hangzhou.aliyuncs.com/image-storage/nfspluginnfsplugin:v4.6.0
deploy/csi-nfs-node.yaml:          imagePullPolicy: "IfNotPresent"
deploy/csi-snapshot-controller.yaml:          image: registry.aliyuncs.com/google_containers/snapshot-controller:v8.2.1

我们来看看替换命令

sed -i 's#gcr.io/k8s-staging-sig-storage#registry.aliyuncs.com/google_containers#/g' deploy/*.yaml
sed -i 's#registry.k8s.io/sig-storage#registry.aliyuncs.com/google_containers#g' deploy/*.yaml

注意有个特殊镜像需要单独替换(nfsplug:)这个镜像可以手动修改为下面镜像(切记)

registry.cn-hangzhou.aliyuncs.com/image-storage/nfspluginnfsplugin:v4.6.0

完成镜像地址修改后,就可以执行部署了。

直接执行 ./deploy/install-driver.sh  就等会就部署好了

./deploy/install-driver.sh

部署完成大概如下图样子

一般情况 csi-nfs-controller 容器启动有点问题,可以做如下修改

vim deploy/csi-nfs-controller.yaml (编辑 将csi-resizere 信息删除或者注释)由于csi-resizer 可能启动不了,所以将关于 csi-resizer的信息删除或者注释了,一般不用调整磁盘大小- name: csi-resizerimage: registry.aliyuncs.com/google_containers/csi-resizer:v1.13.2args:- "-csi-address=$(ADDRESS)"- "-v=2"- "-leader-election"- "--leader-election-namespace=$(POD_NAMESPACE)"- '-handle-volume-inuse-error=false'env:- name: ADDRESSvalue: /csi/csi.sock- name: POD_NAMESPACEvalueFrom:fieldRef:fieldPath: metadata.namespacevolumeMounts:- name: socket-dirmountPath: /csiresources:limits:memory: 200Mi

经过以上修改后 csi-nfs 就部署完成 

五 创建 storageclass 磁盘类

vim storageclass-nfs.yaml  将下面内容直接复制粘贴进去就行

注意修改下 nfs服务器ip及目录信息就行了

---
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:annotations:storageclass.kubernetes.io/is-default-class: "true"name: nfs-csi
provisioner: nfs.csi.k8s.io
parameters:server: 192.168.3.121share: /var/nfs/nano# csi.storage.k8s.io/provisioner-secret is only needed for providing mountOptions in DeleteVolume# csi.storage.k8s.io/provisioner-secret-name: "mount-options"# csi.storage.k8s.io/provisioner-secret-namespace: "default"
reclaimPolicy: Delete
volumeBindingMode: Immediate
allowVolumeExpansion: true
mountOptions:- nfsvers=4.1

kubectl apply -f storageclass-nfs.yaml 

这就完成了磁盘类创建,后面使用就可以直接调用了。

六 总结

 经过上面步骤一步步完成就完成了csi-nfs 部署,给k8s 对接上了nfs存储了。

好,感谢阅读,欢迎评论区留言反馈问题。

相关文章:

  • R语言绘图 | 渐变火山图
  • STM32F103_LL库+寄存器学习笔记22 - 基础定时器TIM实现1ms周期回调
  • MySQL索引底层数据结构与算法
  • 如何配置activemq,支持使用wss协议连接。
  • 如何避免和恢复因终端关闭导致的 LoRA 微调中断
  • 无锡哲讯科技:引领芯片封装SAP系统的智能化革命
  • 前端性能优化3:深入分析 Web Worker 和 Service Worker
  • Gmsh+OCC对应版本库编译
  • LabVIEW 程序运行时内存不足报错原因
  • 故障诊断模型评估——混淆矩阵,如何使样本量一致(上)
  • 【计算机组成原理】第二部分 存储器--分类、层次结构
  • Linux的域名解析服务器
  • 专题四:综合练习( 找出所有子集的异或总和再求和)
  • 每日Prompt:发光线条解剖图
  • 华秋2025电子设计与制造技术研讨会(华东站)成功举办!
  • 技术干货 | 如何用模块化仪器高效测试嵌入式微控制器?
  • 嵌入式培训之数据结构学习(二)顺序表与单向链表
  • 手机换IP真的有用吗?可以干什么?
  • 解锁向量数据库:实现高效过滤与管理的实用方法
  • OpenCV的CUDA模块进行图像处理
  • “80后”德州市接待事务中心副主任刘巍“拟进一步使用”
  • 海运港口股掀涨停潮!回应关税下调利好,有货代称美线舱位爆了
  • 北美票房|昔日偶像风光不再,乔什·哈内特新片开画不佳
  • 2025年度十大IP!IP SH荣膺文化综合类TOP10
  • A股三大股指集体高开
  • 阶跃星辰CEO姜大昕:追求智能上限仍是最重要的事,多模态的“GPT-4时刻”尚未到来