当前位置: 首页 > news >正文

轻松掌握K8S目录持久卷PV/PVC的kubectl操作知识点04

1、介绍

在docker中可以将容器中的目录挂载出来,在k8s中pod可以部署在不同节点,假如该节点的机器宕机了,k8s可能就会将此Pod转移到其他机器,就不是原先的机器了。k8s有自己的一套挂载方案,如下图所示,

原理为将所有节点的挂载的目录统一抽象管理为叫做 存储层的概念,使用技术如NFS网络文件系统,在每一个节点都会有如50G的存储空间,该空间之间的数据是同步的,这样就解决了某一节点宕机了,Pod转移到其他节点了依然可以获取到挂载的目录。

在这里插入图片描述

1、搭建NFS网络文件系统

在这里插入图片描述

  • 所有机器安装 yum install -y nfs-utils
  • nfs主节点,这里我们对应k8s的主节点(我配置两个主节点,选择了其中一个) 创建同步文件的目录 mkdir -p /nfs/k8s/data,设置暴露目录echo "/nfs/k8s/data/ *(insecure,rw,sync,no_root_squash)" > /etc/exports
  • nfs主节点启动RPC远程绑定现在启动并且开机也要启动 systemctl enable rpcbind --now
  • nfs主节点启动nfs 服务端,并且开启自动启动 systemctl enable nfs-server --now
  • nfs主节点使配置生效 exportfs -r, 输出目录查看 exportfs

在这里插入图片描述

  • 其他节点可检查哪些目录可以同步,执行命令 showmount -e 192.168.134.110,注意IP换成自己的

在这里插入图片描述

  • 其他节点也创建同步的目录,目录名随意,我定义成一样的 mkdir -p /nfs/k8s/data
  • 将主节点和其他节点关联起来 ,在其他节点执行 mount -t nfs 192.168.134.110:/nfs/k8s/data /nfs/k8s/data
  • 测试,可以在任意一个节点添加修改文件,去其他检查是否同步修改了
2、原生方式创建Deployment并应用目录挂载到nfs

如下使用yaml的方式将镜像nginx中的目录/usr/share/nginx/html挂载到了nfs服务端的/nfs/data/nginx-pv目录,只要在挂载目录/nfs/data/nginx-pv里加文件,也会同步到了pod里/usr/share/nginx/html

kubectl apply -f nfs-demo.yaml

apiVersion: apps/v1
kind: Deployment
metadata:labels:app: nginx-pv-demoname: nginx-pv-demo
spec:replicas: 2selector:matchLabels:app: nginx-pv-demotemplate:metadata:labels:app: nginx-pv-demospec:containers:- image: nginxname: nginxvolumeMounts:- name: htmlmountPath: /usr/share/nginx/htmlvolumes:- name: htmlnfs:server: 192.168.134.110path: /nfs/data/nginx-pv

注意挂载的目录一定要先创建好否则查询当前应用时出现如下一直在创建中

在这里插入图片描述

进入这个pod详细信息,可以看到报错的详细问题 kubectl describe pod nginx-pv-demo-dc6884649-4phvz

在这里插入图片描述

这种方式缺点:1、需要提前创建好挂载的机器目录;2、当Pod删除,机器挂载的目录不会同时删除;3、无法指定目录的存储大小

3、使用静态PV/PVC持久卷方式

PV持久卷,可以指定大小,当PVC删除,对应的PV也会删除

在这里插入图片描述

PV:持久卷(Persistent Volume),将应用需要持久化的数据保存到指定位置

PVC:持久卷申明(Persistent Volume Claim),申明需要使用的持久卷规格

2、存储挂载PV/PVC实战

1、在nfs目录中创建PV的静态目录
#nfs主节点
mkdir -p /nfs/k8s/pv/data/01
mkdir -p /nfs/k8s/pv/data/02
mkdir -p /nfs/k8s/pv/data/03
2、创建静态PV持久卷

执行命令 kubectl apply -f pvdemo.yaml

以下可以写在一个文件中 ,用—分割,会自动识别成三个文件,server为主节点的IP地址。storageClassName表示一个标志,在后面创建PVC时需要用到。

apiVersion: v1
kind: PersistentVolume
metadata:name: pv01-10m
spec:capacity:storage: 10MaccessModes:- ReadWriteManystorageClassName: nfsnfs:path: /nfs/k8s/pv/data/01server: 192.168.134.110
---
apiVersion: v1
kind: PersistentVolume
metadata:name: pv02-1gi
spec:capacity:storage: 1GiaccessModes:- ReadWriteManystorageClassName: nfsnfs:path: /nfs/k8s/pv/data/02server: 192.168.134.110
---
apiVersion: v1
kind: PersistentVolume
metadata:name: pv03-3gi
spec:capacity:storage: 3GiaccessModes:- ReadWriteManystorageClassName: nfsnfs:path: /nfs/k8s/pv/data/03server: 192.168.134.110
3、查询PV持久卷

在这里插入图片描述

简写

在这里插入图片描述

4、创建PVC

pvc.yaml如下:storageClassName: nfs 对应创建的PV

kind: PersistentVolumeClaim
apiVersion: v1
metadata:name: nginx-pvc
spec:accessModes:- ReadWriteManyresources:requests:storage: 200MistorageClassName: nfs

因为申请的storage: 200Mi 指定了大小,所以被分配了拥有1G容量的PV

在这里插入图片描述

5、删除PVC

对应的PV也会被释放Released

在这里插入图片描述

6、查询PVC

在这里插入图片描述

7、创建Deployment应用同时挂载PVC

执行 kubectl apply -f pvcdemo.yaml

将创建好的PVC nginx-pvc挂载到当前创建的应用中。

apiVersion: apps/v1
kind: Deployment
metadata:labels:app: nginx-deploy-pvcname: nginx-deploy-pvc
spec:replicas: 2selector:matchLabels:app: nginx-deploy-pvctemplate:metadata:labels:app: nginx-deploy-pvcspec:containers:- image: nginxname: nginxvolumeMounts:- name: htmlmountPath: /usr/share/nginx/htmlvolumes:- name: htmlpersistentVolumeClaim:claimName: nginx-pvc
8、测试

修改挂载的目录,即可查看文件有没有同步。

http://www.lryc.cn/news/60945.html

相关文章:

  • Appuploader证书申请教程
  • acwing17给了一个头节点,从尾到头输出链表的元素,顺便练练容器
  • Linux 性能优化大全!
  • 精通 TensorFlow 2.x 计算机视觉:第一部分
  • mulesoft MCIA 常用词汇、知识点汇总
  • Python 单样本学习实用指南:1~6 全
  • 心血管疾病数据探索分析
  • Pandas的应用-1
  • 【状态估计】电力系统状态估计的虚假数据注入攻击建模与对策(Matlab代码实现)
  • 【Spring】Spring @Import注解的使用和源码分析
  • C++中的类与对象
  • 探索Qt图像处理的奥秘:从入门到精通
  • springboot+vue企业人事人力资源管理系统java公司员工出差考勤办公OA系统
  • 设计模式-模板模式在Java中的使用示例
  • 回溯算法及其应用
  • 如何一步步打造完美的成绩查询系统平台?
  • P1026 [NOIP2001 提高组] 统计单词个数
  • CTFHub | eval执行
  • IP协议头
  • 【xxl-job定时任务框架详解】
  • 7、在vscode上利用cmake构建多文件C++工程
  • Linux操作系统网络模块
  • 不同批次板子采集到的传感器压力值不同
  • 设计模式--原型模式
  • C++智能指针shared_ptr详解
  • 家政服务APP小程序开发功能详解
  • 【C++】deque的实现原理简单介绍
  • UWB隧道人员定位技术应用,施工作业安全精准保障
  • 15.2 矩阵链乘法
  • 向隐形冠军学习:聚焦人效,用时间管理提效益