151 lines
4.3 KiB
YAML
151 lines
4.3 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: 172.10.125.92: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: 172.10.125.92 #NFS Server IP地址
|
||
- name: NFS_PATH
|
||
value: /nfsdata #NFS挂载卷
|
||
volumes:
|
||
- name: nfs-client-root
|
||
nfs:
|
||
server: 172.10.125.92 #NFS Server IP地址
|
||
path: /nfsdata #NFS 挂载卷
|
||
---
|
||
---
|
||
kind: PersistentVolumeClaim
|
||
apiVersion: v1
|
||
metadata:
|
||
name: test-claim
|
||
annotations:
|
||
volume.beta.kubernetes.io/storage-class: "nfs-prod-distribute" #与nfs-StorageClass.yaml metadata.name保持一致
|
||
spec:
|
||
accessModes:
|
||
- ReadWriteOnce
|
||
storageClassName: nfs-prod-distribute
|
||
resources:
|
||
requests:
|
||
storage: 1Mi
|
||
---
|
||
kind: Pod
|
||
apiVersion: v1
|
||
metadata:
|
||
name: test-pod
|
||
spec:
|
||
containers:
|
||
- name: test-pod
|
||
image: 172.10.125.92:8033/rancher/busybox
|
||
command:
|
||
- "/bin/sh"
|
||
args:
|
||
- "-c"
|
||
- "touch /mnt/NFS-CREATE-SUCCESS && exit 0 || exit 1" #创建一个SUCCESS文件后退出
|
||
volumeMounts:
|
||
- name: nfs-pvc
|
||
mountPath: "/mnt"
|
||
restartPolicy: "Never"
|
||
volumes:
|
||
- name: nfs-pvc
|
||
persistentVolumeClaim:
|
||
claimName: test-claim #与PVC名称保持一致 |