114 lines
3.5 KiB
YAML
114 lines
3.5 KiB
YAML
# 修改NS,NFS server IP ,NFS path
|
||
# 修改 镜像私有地址
|
||
|
||
apiVersion: v1
|
||
kind: ServiceAccount
|
||
metadata:
|
||
name: nfs-client-provisioner
|
||
# replace with namespace where provisioner is deployed
|
||
namespace: kube-system #根据实际环境设定namespace,下面类同
|
||
---
|
||
kind: ClusterRole
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
metadata:
|
||
name: nfs-client-provisioner-runner
|
||
rules:
|
||
- apiGroups: [""]
|
||
resources: ["persistentvolumes"]
|
||
verbs: ["get", "list", "watch", "create", "delete"]
|
||
- apiGroups: [""]
|
||
resources: ["persistentvolumeclaims"]
|
||
verbs: ["get", "list", "watch", "update"]
|
||
- apiGroups: ["storage.k8s.io"]
|
||
resources: ["storageclasses"]
|
||
verbs: ["get", "list", "watch"]
|
||
- apiGroups: [""]
|
||
resources: ["events"]
|
||
verbs: ["create", "update", "patch"]
|
||
---
|
||
kind: ClusterRoleBinding
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
metadata:
|
||
name: run-nfs-client-provisioner
|
||
subjects:
|
||
- kind: ServiceAccount
|
||
name: nfs-client-provisioner
|
||
# replace with namespace where provisioner is deployed
|
||
namespace: kube-system
|
||
roleRef:
|
||
kind: ClusterRole
|
||
# name: nfs-client-provisioner-runner
|
||
name: cluster-admin
|
||
apiGroup: rbac.authorization.k8s.io
|
||
---
|
||
kind: Role
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
metadata:
|
||
name: leader-locking-nfs-client-provisioner
|
||
# replace with namespace where provisioner is deployed
|
||
namespace: kube-system
|
||
rules:
|
||
- apiGroups: [""]
|
||
resources: ["endpoints"]
|
||
verbs: ["get", "list", "watch", "create", "update", "patch"]
|
||
---
|
||
kind: RoleBinding
|
||
apiVersion: rbac.authorization.k8s.io/v1
|
||
metadata:
|
||
name: leader-locking-nfs-client-provisioner
|
||
subjects:
|
||
- kind: ServiceAccount
|
||
name: nfs-client-provisioner
|
||
# replace with namespace where provisioner is deployed
|
||
namespace: kube-system
|
||
roleRef:
|
||
kind: Role
|
||
name: leader-locking-nfs-client-provisioner
|
||
apiGroup: rbac.authorization.k8s.io
|
||
|
||
---
|
||
apiVersion: storage.k8s.io/v1
|
||
kind: StorageClass
|
||
metadata:
|
||
name: nfs-prod-distribute
|
||
provisioner: cmlc-nfs-storage #这里的名称要和provisioner配置文件中的环境变量PROVISIONER_NAME保持一致parameters: archiveOnDelete: "false"
|
||
---
|
||
apiVersion: apps/v1
|
||
kind: Deployment
|
||
metadata:
|
||
name: nfs-client-provisioner
|
||
labels:
|
||
app: nfs-client-provisioner
|
||
# replace with namespace where provisioner is deployed
|
||
namespace: kube-system #与RBAC文件中的namespace保持一致
|
||
spec:
|
||
replicas: 1
|
||
selector:
|
||
matchLabels:
|
||
app: nfs-client-provisioner
|
||
strategy:
|
||
type: Recreate
|
||
template:
|
||
metadata:
|
||
labels:
|
||
app: nfs-client-provisioner
|
||
spec:
|
||
serviceAccountName: nfs-client-provisioner
|
||
containers:
|
||
- name: nfs-client-provisioner
|
||
image: 192.168.233.100:8033/cmii/nfs-subdir-external-provisioner:v4.0.2
|
||
volumeMounts:
|
||
- name: nfs-client-root
|
||
mountPath: /persistentvolumes
|
||
env:
|
||
- name: PROVISIONER_NAME
|
||
value: cmlc-nfs-storage #provisioner名称,请确保该名称与 nfs-StorageClass.yaml文件中的provisioner名称保持一致
|
||
- name: NFS_SERVER
|
||
value: 192.168.233.100 #NFS Server IP地址
|
||
- name: NFS_PATH
|
||
value: /nfsdata #NFS挂载卷
|
||
volumes:
|
||
- name: nfs-client-root
|
||
nfs:
|
||
server: 192.168.233.100 #NFS Server IP地址
|
||
path: /nfsdata #NFS 挂载卷 |