k8s 安装笔记 - 共享NAS文件服务
温馨提示:
本文最后更新于 2023年07月10日
,已超过 649 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
NFS概述
NFS是一种基于TCP/IP传输的网络文件系统协议。通过使用NFS协议,客户机可以像访问本地目录一样访问远程NFS服务器中的共享资源。
NFS也是NAS存储设备必然支持的一种协议,但是因为没有用户的认证机制,而且数据在网络上明文传输,安全性很差,所以一般只能在局域网中使用。
安装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
正文到此结束
- 本文标签: Linux k8s
- 本文链接: https://www.letcode.cn/article/10
- 版权声明: 本文由Jack.Chen原创发布,转载请遵循《 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权