k8s使用mac上自带的NFS

k8s使用mac上自带的NFS服务

之前文章里有记录如何在mac电脑上使用docker,并搭建k8s集群。最近在开发测试的时候,遇到k8s挂载持久卷的问题。本来想在开发的电脑上搭建一个NFS服务,经过在网上一番搜索发现mac电脑本身就带有一个NFS服务。这篇文章主要记录一下如何在mac上开启并配置NFS服务,以及如何在k8s上使用NFS。

1 配置并开启NFS服务

Mac上的NFS服务是作为系统服务提供的,可以使用nfsd status命令查看nfsd当前的状态。

1.1 配置共享目录

Mac自带的NFS服务的配置文件路径为/etc/exports,默认该文件是不存在的,需要使用sudo权限进行创建。

sudo vi /etc/exports

添加如下内容:

/Users/shirukai/opt/nfs_data -alldirs -maproot=root:wheel -network 20.5.1.0 -mask 255.255.255.0

说明:

  1. /Users/shirukai/opt/nfs_data 指定共享目录
  2. -alldirs 共享目录下的所有目录
  3. -maproot 把client端的root用户映射为Mac OS上的root,client端的root组映射为Mac OS上的wheel (gid=0) 组
  4. -network -mask 指定本工作网段

配置文件修改完成后使用nfsd checkexports检查配置是否正确:

nfsd checkexports

1.2 配置NFS

要想在k8s使用,需要修改NFS的一个配置文件/etc/nfs.conf并添加如下内容:

nfs.server.mount.require_resv_port = 0

配置说明,执行命令man nfs.conf查看

1.3 启动服务

使用 nfsd start启动NFS服务,如下为常用的服务命令:

sudo nfsd start # 启动服务
sudo nfsd stop # 停止服务
sudo nfsd restart # 重启服务
sudo nfsd status # 查看状态
sudo nfsd enable # 开机自启
sudo nfsd disable # 禁止开机自启

服务启动后,通过showmount -e查看共享状态:

Exports list on localhost:
/Users/shirukai/opt/nfs_data        20.5.1.0

2 k8s中使用NFS

2.1 NFS PersistentVolume

前面我们已经在mac上启动了一个NFS服务,现在通过在k8s上创建一个PersistentVolume来使用NFS。

创建一个PV,编辑配置文件nfs-pv-1.yaml,内容如下:

apiVersion: v1
kind: PersistentVolume # ①
metadata:
  name: nfspv1 # ②
spec:
  mountOptions:
    - nfsvers=3
    - nolock
  capacity:
    storage: 10Gi # ③
  accessModes:
    - ReadWriteOnce # ④
  persistentVolumeReclaimPolicy: Recycle # ⑤
  storageClassName: nfs # ⑥
  nfs:
    path: /Users/shirukai/opt/nfs_data # ⑦
    server: 20.5.1.123 # ⑧

① 指定k8s资源类型为PersistentVolume

② 指定PV名称为nfspv1

③ 指定PV容量为10G

④ accessMode指定访问模式为ReadWriteOnce,支持的访问模式有3种:

​ ReadWriteOnce 表示PV能以read-write模式mount到单个节点

​ ReadWriteMany表示PV能以read-write模式mount到多个节点

​ ReadOnlyMany表示PV能以read-only模式mount到多个节点

⑤ persistentVolumeReclaimPolicy指定PV的回收策略为Recycle,支持的策略有3种:

​ Retain表示需要管理员手工回收

​ Recycle表示清除PV中的数据,效果相当于执行rm -rf /thevolume/*

​ Delete表示删除Storage Provider上的对应存储资源

⑥ storageClassName指定PV的class为nfs。相当于为PV设置了一个分类,PVC可以指定class申请相应class的PV

⑦ 指定PV在NFS服务器上对应的目录

⑧ 指定NFS服务器的地址

配置文件编写完成后,使用如下命令创建对应的PV

kubectl apply -f nfs-pv-1.yaml

查看pv状态

kubectl get pv

NAME     CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS      CLAIM   STORAGECLASS   REASON   AGE
nfspv1   10Gi       RWO            Recycle          Available           nfs                     42m

STATUS为Available表示nfspv1就绪,可以被PVC申请。

2.2 PersistentVolumeClaim

下面创建PVC,编辑nfs-pvc-1.yaml文件

apiVersion: v1
kind: PersistentVolumeClaim # ①
metadata:
  name: nfspvc1 # ②
spec:
  accessModes:
    - ReadWriteOnce # ③
  resources:
    requests:
      storage: 6Gi # ④
  storageClassName: nfs # ⑤

① 指定资源类型为PersistentVolumeClaim

② 指定pvc名称

③ 访问模式

④ 申请PV的容量

⑤ PV的class

创建PVC

kubectl apply -f nfs-pvc-1.yaml 
(base) shirukai@shirukaideMacBook-Pro pv % kubectl get pvc
NAME      STATUS   VOLUME   CAPACITY   ACCESS MODES   STORAGECLASS   AGE
nfspvc1   Bound    nfspv1   10Gi       RWO            nfs            85s

2.3 使用存储

pvc创建好之后,我们就可以在pod里使用了,下面创建一个简单的pod来测试一下。编辑pod1.yaml

apiVersion: v1
kind: Pod
metadata:
  name: mypod1
spec:
  containers:
    - name: mypod1
      image: busybox
      args:
      - /bin/sh
      - -c
      - sleep 30000
      volumeMounts:
      - mountPath: "/mydata"
        name: mydata
  volumes:
    - name: mydata
      persistentVolumeClaim:
        claimName: nfspvc1

创建Pod

kubectl apply -f pod1.yaml

在容器里创建一个文件

kubectl exec mypod1 touch /mydata/hello

NFS共享目录

(base) shirukai@shirukaideMacBook-Pro nfs_data % ls
hello

参考:https://xiaozhuanlan.com/topic/8560297431

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供相关的指导。首先,您需要在 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` 目录中。 希望这些信息能够对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值