💡 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
转载地址:我的博客