K8S NFS 服务 安装和使用

💡 NFS概述 NFS是一种基于TCP/IP传输的网络文件系统协议。通过使用NFS协议,客户机可以像访问本地目录一样访问远程NFS服务器中的共享资源。 NFS也是NAS存储设备必然支持的一种协议,但是因为没有用户的认证机制,而且数据在网络上明文传输,安全性很差,所以一般只能在局域网中使用。 安装nfs-utils、rpcbind软件包 NFS服务的实现依赖于RPC机制,以完成远程到本地的映射过程。在Centos 7 系统中,需要安装nfs-utils、rpcbind 软件包来提供NFS共享服务,前者用于NFS共享发布和访问,后者用于RPC支持。手工加载NFS共享服务时,应先启动rpcbind,再启动nfs。

安装nfs服务(所有的节点都需要安装)

hostPath模式,nfs文件目录同步

yum install -y nfs-utils

创建共享目录(所有的节点)

mkdir -p /data/nfs/jenkins
vim /etc/exports			
#添加下面的参数
/data/nfs/jenkins *(rw,no_root_squash)

启动服务(一个服务即可,需要三个服务器都能访问)

systemctl enable nfs	
systemctl start nfs
# 查看服务
showmount -e 172.30.10.201(当前机器的IP)

nfs 部署到k8s

kind: Deployment
apiVersion: apps/v1
metadata:
  name: nfs-client-provisioner
  namespace: kube-system
spec:
  replicas: 1
  strategy:
    type: Recreate
  selector:
    matchLabels:
      app: nfs-client-provisioner
  template:
    metadata:
      labels:
        app: nfs-client-provisioner
    spec:
      serviceAccountName: nfs-client-provisioner
      containers:
        - name: nfs-client-provisioner
          image: quay.io/external_storage/nfs-client-provisioner:latest
          volumeMounts:
            - name: nfs-client-root
              mountPath: /persistentvolumes
          env:
            - name: PROVISIONER_NAME
              # 根据自己的名称来修改,与 storageclass.yaml 中的 provisioner 名字一致
              value: my-nfs-name                 
            - name: NFS_SERVER
              # NFS服务器所在的 ip
              value: 172.30.10.201        
            - name: NFS_PATH
              # 共享存储目录
              value: /data/nfs                  
      volumes:
        - name: nfs-client-root
          nfs:
            # NFS服务器所在的 ip
            server: 172.30.10.201 
            # 共享存储目录        
            path: /data/nfs                     

StorageClass 配置NFS地址和路径,关联pvc 一起使用,自动创建 pv

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: class-nfs-01
  namespace: devops
provisioner: my-nfs-01
parameters:
  server: 172.30.10.201
  path: /data/nfs
  readOnly: "false"

nfs pvc

# pvc-nfs.yaml
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: nfs-pvc
  namespace: devops
spec:
  storageClassName: class-nfs-01
  accessModes: [ReadWriteOnce]
  resources:
    requests:
      storage: 15Gi

转载地址:我的博客

好的,我可以为您提供相关的指导。首先,您需要在 Kubernetes 集群中安装 NFS 客户端组件,以便从集群中的 Pod 访问 NFS 存储。 安装 NFS 客户端组件的方法因 Linux 发行版而异。在大多数基于 Debian 的发行版中,您可以使用以下命令安装 NFS 客户端: ``` sudo apt-get update sudo apt-get install -y nfs-common ``` 在基于 Red Hat 的发行版中,您可以使用以下命令安装 NFS 客户端: ``` sudo yum update sudo yum install -y nfs-utils ``` 安装完成后,您需要创建一个持久卷声明(PersistentVolumeClaim)来声明您想要使用 NFS 存储。下面是一个示例 YAML 文件,用于创建一个名为 `nfs-pvc` 的持久卷声明: ``` apiVersion: v1 kind: PersistentVolumeClaim metadata: name: nfs-pvc spec: accessModes: - ReadWriteMany resources: requests: storage: 10Gi storageClassName: "" ``` 在这个 YAML 文件中,我们指定了访问模式为 `ReadWriteMany`,这意味着多个 Pod 可以同时读写该卷。我们还指定了存储容量为 10GB。 接下来,您需要创建一个持久卷(PersistentVolume),并将其绑定到您的 NFS 存储。下面是一个示例 YAML 文件,用于创建一个名为 `nfs-pv` 的持久卷: ``` apiVersion: v1 kind: PersistentVolume metadata: name: nfs-pv spec: capacity: storage: 10Gi accessModes: - ReadWriteMany nfs: server: <NFS服务器IP> path: /path/to/nfs ``` 在这个 YAML 文件中,我们指定了访问模式为 `ReadWriteMany`,这与我们在持久卷声明中指定的访问模式相同。我们还指定了存储容量为 10GB,以及 NFS 服务器的 IP 地址 NFS 存储的路径。 最后,您需要将持久卷声明绑定到您的 Pod。下面是一个示例 YAML 文件,用于创建一个名为 `nfs-pod` 的 Pod,并将其绑定到我们之前创建的 `nfs-pvc` 持久卷声明: ``` apiVersion: v1 kind: Pod metadata: name: nfs-pod spec: containers: - name: nginx image: nginx volumeMounts: - name: nfs-volume mountPath: /mnt/nfs volumes: - name: nfs-volume persistentVolumeClaim: claimName: nfs-pvc ``` 在这个 YAML 文件中,我们指定了一个名为 `nfs-volume` 的卷,并将其绑定到我们之前创建的 `nfs-pvc` 持久卷声明。我们还指定了一个名为 `nginx` 的容器,该容器将挂载 `nfs-volume` 卷到 `/mnt/nfs` 目录中。 希望这些信息能够对您有所帮助!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值