k8s1.19.16部署nfs-storageclass

一、stargeclass动态持久化存储简单介绍

PV是运维人员来创建的,开发操作PVC,可是大规模集群中可能会有很多PV,如果这些PV都需要运维手动来处理这也是一件很繁琐的事情,所以就有了动态供给概念,也就是Dynamic Provisioning。而我们上面的创建的PV都是静态供给方式,也就是Static Provisioning。而动态供给的关键就是StorageClass,它的作用就是创建PV模板。

创建StorageClass里面需要定义PV属性比如存储类型、大小等;另外创建这种PV需要用到存储插件。最终效果是,用户提交PVC,里面指定存储类型,如果符合我们定义的StorageClass,则会为其自动创建PV并进行绑定。

二、部署nfs-storageclass

1、部署nfs服务

kubernetes本身支持的动态PV创建不包括nfs,所以需要使用额外插件nfs-client和rpcbind

在master节点上安装nfs服务,并启动

yum -y install nfs-utils rpcbind
systemctl start rpcbind
systemctl enable rpcbind
systemctl start nfs
systemctl enable nfs

在node节点上安装nfs(不需要安装rpcbind),并启动

yum -y install nfs-utils
systemctl start nfs
systemctl enable nfs

在node节点上挂载nfs目录

mkdir -p /data2/k8s/storageclass

vim /etc/exports
/data2/k8s/storageclass  192.168.238.0/24(rw,sync,no_root_squash)

2、拉取nfs-storageclass镜像

需要nfs-client-provisioner这个镜像,我这边放到到dockerhub上了,直接拉去就行

docker pull xingergou/nfs-client-provisioner:latest

3、编写nfs-storageclass-的namepsace

apiVersion: v1
kind: Namespace
metadata:
   name: storage-class
   labels:
     name: storage-class

4、编写nfs-storageclass的RBAC授权文件

apiVersion: v1
kind: ServiceAccount
metadata:
  name: nfs-client-provisioner
  namespace: storage-class
---
#定义账号拥有哪些资源的哪些权限
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
  name: nfs-client-provisioner-cr
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: ["list","watch","create","update","patch"]
  - apiGroups: [""]
    resources: ["endpoints"]
    verbs: ["create","delete","get","list","watch","patch","update"]
---
#将角色与账号进行绑定
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: nfs-client-provisioner-crb
subjects:
  - kind: ServiceAccount
    name: nfs-client-provisioner
    namespace: storage-class
roleRef:
  kind: ClusterRole
  name: nfs-client-provisioner-cr
  apiGroup: rbac.authorization.k8s.io

5、编写nfs-storageclass的部署yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nfs-client-provisioner
  namespace: storage-class
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.238.153/nfs/nfs-client-provisioner:latest
          env:
            - name: PROVISIONER_NAME				#给nfs-client-provisioner起个名字
              value: nfs-storage-01
            - name: NFS_SERVER
              value: 192.168.238.153        				 #nfs server地址
            - name: NFS_PATH
              value: /data2/k8s/storageclass    			 #nfs共享路径
          volumeMounts:
            - name: nfs-client-root
              mountPath: /persistentvolumes						#具体挂载路径
      volumes:										#定义一个nfs类型的volume,将nfs挂载到容器中
        - name: nfs-client-root
          nfs:
            server: 192.168.238.153
            path: /data2/k8s/storageclass

6、创建storageclass资源文件,指定使用对象

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: nfs-storageclass
provisioner: nfs-storage-01			#指定使用哪个nfs-client-provisioner
allowVolumeExpansion: true          #可以动态扩容
reclaimPolicy: Retain				#回收策略

7、测试是否能够使用

这个专栏的redis和mysql都是用strageclass这种模式部署的

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值