K8S NFS持久存储配置

K8S NFS 持久存储配置

在Kubernetes(K8S)中配置NFS(Network File System)作为持久存储通常涉及以下步骤:

1. 准备 NFS 服务器

首先,你需要一个运行NFS服务的服务器。这可以是Kubernetes集群中的一个节点,也可以是集群外部的服务器。

1.1 安装 NFS 服务

在NFS服务器上,安装NFS服务软件包。这通常可以通过包管理器来完成。例如,在基于Debian的系统上,你可以使用以下命令:

bash

|---|---------------------------------------------------|
| | sudo apt-get update |
| | sudo apt-get install nfs-kernel-server nfs-common |

1.2 创建共享目录

在NFS服务器上,创建一个目录作为共享点。例如:

bash

|---|-------------------------------|
| | sudo mkdir /path/to/nfs/share |

1.3 配置 NFS 共享

编辑NFS服务器的/etc/exports文件,添加共享目录及其访问权限。例如:

bash

|---|----------------------------------------------------------------------------------|
| | echo "/path/to/nfs/share *(rw,sync,no_root_squash)" | sudo tee -a /etc/exports |

1.4 重启 NFS 服务

在NFS服务器上重启NFS服务,使配置生效:

bash

|---|------------------------------------------|
| | sudo systemctl restart nfs-kernel-server |

2. Kubernetes 集群中配置 NFS 客户端

在Kubernetes集群的每个节点上,你需要安装NFS客户端工具,以便它们可以挂载NFS共享。

2.1 安装 NFS 客户端

在每个Kubernetes节点上安装NFS客户端软件包:

bash

|---|---------------------------------|
| | sudo apt-get install nfs-common |

3. 创建 PersistentVolume (PV)

在Kubernetes中,你需要创建一个PersistentVolume(PV)资源来代表NFS共享。PV是集群中的一块存储,可以由PersistentVolumeClaim(PVC)来请求。

下面是一个PV的YAML示例,它使用NFS作为后端存储:

yaml

|---|---------------------------------------|
| | apiVersion: v1 |
| | kind: PersistentVolume |
| | metadata: |
| | name: nfs-pv |
| | spec: |
| | capacity: |
| | storage: 1Gi |
| | volumeMode: Filesystem |
| | accessModes: |
| | - ReadWriteMany |
| | persistentVolumeReclaimPolicy: Retain |
| | nfs: |
| | path: /path/to/nfs/share |
| | server: nfs-server-ip |

在这个示例中,capacity定义了存储的大小,volumeMode指定了卷的类型(这里是文件系统),accessModes定义了卷的访问模式(这里是读写多个节点),nfs部分包含了NFS服务器的IP地址和共享路径。

4. 创建 PersistentVolumeClaim (PVC)

然后,你需要在需要访问NFS存储的Pod中创建一个PersistentVolumeClaim(PVC)。PVC是用户对存储的请求。

下面是一个PVC的YAML示例:

yaml

|---|-----------------------------|
| | apiVersion: v1 |
| | kind: PersistentVolumeClaim |
| | metadata: |
| | name: nfs-pvc |
| | spec: |
| | accessModes: |
| | - ReadWriteMany |
| | resources: |
| | requests: |
| | storage: 1Gi |

在这个示例中,accessModes指定了所请求的访问模式,resources.requests.storage指定了所需的存储容量。

5. Pod 中使用 PVC

最后,在你的Pod配置中,你可以通过定义一个卷(Volume)来引用PVC,并在容器中使用这个卷。

下面是一个Pod配置示例,它使用了之前创建的PVC:

yaml

|---|-------------------------------|
| | apiVersion: v1 |
| | kind: Pod |
| | metadata: |
| | name: my-pod |
| | spec: |
| | containers: |
| | - name: my-container |
| | image: my-image |
| | volumeMounts: |
| | - name: nfs-volume |
| | mountPath: /path/to/mount/nfs |
| | volumes: |
| | - name: nfs-volume |
| | persistentVolumeClaim: |
| | claimName: nfs-pvc |

在这个示例中,volumeMounts定义了容器内部的挂载点,而volumes部分指定了使用哪个PVC。

6. 验证配置

一旦Pod被创建,你可以通过执行kubectl exec命令进入Pod,并检查挂载点是否可用。你也可以查看Pod的描述信息来确认卷是否已成功挂载。

请注意,这些步骤提供了一个基本的指南,并可能需要根据你的具体环境和需求进行调整。例如,你可能需要为NFS服务器配置防火墙规则,以确保Kubernetes节点可以访问NFS共享。此外,NFS版本(例如NFSv3或NFSv4)和网络配置也可能需要特别关注。

相关推荐
AI攻城狮14 小时前
OpenClaw 里 TAVILY_API_KEY 明明写在 ~/.bashrc,为什么还是失效?一次完整排查与修复
人工智能·云原生·aigc
Sheffield17 小时前
Alpine是什么,为什么是Docker首选?
linux·docker·容器
阿里云云原生1 天前
零配置部署顶级模型!函数计算一键解锁 Qwen3.5
云原生
AI攻城狮2 天前
Kimi Bot + OpenClaw 完整配置指南:5 步实现本地 AI Agent 集成
人工智能·云原生·aigc
AI攻城狮2 天前
RAG Chunking 为什么这么难?5 大挑战 + 最佳实践指南
人工智能·云原生·aigc
可观测性用观测云3 天前
云原生网关 Ingress-Nginx 链路追踪实战:OpenTelemetry 采集与观测云集成方案
nginx·kubernetes
哈里谢顿4 天前
Kubernetes Operator核心概念、实现原理和实战开发
云原生
阿里云云原生4 天前
你的 OpenClaw 真的在受控运行吗?
云原生
阿里云云原生4 天前
5 分钟零代码改造,让 Go 应用自动获得全链路可观测能力
云原生·go
Shanyoufusu124 天前
RKE2 单节点集群安装 Rancher+ 私有镜像仓库搭建 完整教程
云原生