14-k8s-基本存储之EmptyDir、HostPath、NFS

2023-10-17 04:12

本文主要是介绍14-k8s-基本存储之EmptyDir、HostPath、NFS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、相关概念
    • 二、EmptyDir存储
    • 三、HostPath存储
    • 四、NFS存储

一、相关概念

  1. 概述

    Volumn定义在Pod上,然后被该Pod里面的多个容器挂载到具体的文件目录下。实现同一个Pod中不同容器之间的数据共享以及数据的持久化存储。Volume的生命周期不和Pod中的单个容器的生命周期有关。Volume的生命周期和Pod的生命周期关系需要根据储存类型来定

  2. kubernetes支持的常见Volume类型

    基本存储:EmptyDir、HostPath、NFS
    高级存储:PV、PVC
    配置存储:ConfigMap、Secret

二、EmptyDir存储

  1. 概述

    EmptyDir在Pod被分配到Node时创建的,它的初始内容为空,并且无须指定宿主机上对应的目录文件,因为kubernetes会自动分配一个目录,当Pod销毁时,EmptyDir中的数据也会被永久删除,所以也被称为临时存储。

  2. 实操逻辑

    1. 先声明一个EmptyDir储存类型的volume
    2. 在一个Pod中准备两个容器nginx和busybox
    3. 将volume分别挂载到两个容器的目录中
    4. 然后nginx容器负责向volume中写日志,busybox中通过命令从volume读取日志文件内容到控制台
    
  3. 编写yml文件:vi /opt/volume-emptydir.yaml

    apiVersion: v1
    kind: Pod
    metadata:name: volume-emptydir
    spec:containers:- name: nginximage: nginx:latestports:- name: nginx-portcontainerPort: 80protocol: TCPvolumeMounts:    # 将logs-volume挂载到nginx容器的/var/log/nginx目录, nginx会将用户的访问日志写入到该目录的access.log文件中- name: logs-volumemountPath: /var/log/nginx- name: busyboximage: busybox:latestcommand: ["/bin/sh", "-c", "tail -f /logs/access.log"] volumeMounts:    # 将logs-volume挂载到busybox容器中的/logs目录- name: logs-volumemountPath: /logsvolumes:    # 声明volume- name: logs-volumeemptyDir: {}
    
  4. 运行:kubectl apply -f /opt/volume-emptydir.yaml

  5. 查看是否启动:kubectl get pod -o wide
    在这里插入图片描述

  6. 测试访问,生成日志: curl 192.169.189.78

  7. 查看日志(-c是指定容器):kubectl logs volume-emptydir -c busybox -f
    在这里插入图片描述

三、HostPath存储

  1. 概述

    HostPath就是将Node主机中的一个实际目录挂载到Pod中,以供容器使用。即使Pod销毁,数据依旧可以保存在Node主机上,也被称为本地存储。

  2. 实操逻辑

    1. 先声明一个HostPath储存类型的volume,数据储存在Node主机的目录中
    2. 在一个Pod中准备两个容器nginx和busybox
    3. 将volume分别挂载到两个容器的目录中
    4. 然后nginx容器负责向volume中写日志,busybox中通过命令从volume读取日志文件内容到控制台
    
  3. 编写yml文件:vi /opt/volume-hostpath.yaml

    apiVersion: v1
    kind: Pod
    metadata:name: volume-hostpath
    spec:containers:- name: nginximage: nginx:latestports:- name: nginx-portcontainerPort: 80protocol: TCPvolumeMounts:    # 将logs-volume挂载到nginx容器的/var/log/nginx目录, nginx会将用户的访问日志写入到该目录的access.log文件中- name: logs-volumemountPath: /var/log/nginx- name: busyboximage: busybox:latestcommand: ["/bin/sh", "-c", "tail -f /logs/access.log"] volumeMounts:    # 将logs-volume挂载到busybox容器中的/logs目录- name: logs-volumemountPath: /logsvolumes:    # 声明volume- name: logs-volumehostPath:path: /root/logstype: DirectoryOrCreate
    

    ps:type类型解析

    DirectoryOrCreate:目录存在就使用,不存在就先创建
    Directory:目录必须存在
    FileOrCreate:文件存在就使用,不存在就先创建
    File:文件必须存在
    Socket:unix socket必须存在
    CharDevice:字符设备必须存在
    BlockDevice:块设备必须存在
    
  4. 启动pod:kubectl apply -f /opt/volume-hostpath.yaml

  5. 查看pod:kubectl get pod volume-hostpath -o wide
    在这里插入图片描述

  6. 访问nginx:curl 192.169.235.141

  7. 查看日志(-c是指定容器):kubectl logs volume-hostpath -c busybox -f
    在这里插入图片描述

  8. 查看节点: kubectl describe pod volume-hostpath
    在这里插入图片描述

  9. 该pod在节点11,则查看日志:ls /root/logs
    在这里插入图片描述

四、NFS存储

  1. 概述

    HostPath虽然可以解决数据持久化问题,但是一旦Node节点故障了,Pod如果转移到别的Node节点上,又会出现问题。此时需要准备单独的网络存储系统。比较常用的是NFS和CIFS

    NFS是一个网络文件存储系统,可以搭建NFS服务器,然后将Pod中的存储直接连接到NFS系统上。无论Pod在节点上怎么转移,只要Node和NFS的对接没有问题,数据就可以成功访问。

  2. 搭建NFS服务器(所有的k8s服务器)

    ps1:生产环境可以使用nfs + keepalived做高可用防止单点故障,rsync + inotify实现主备间共享数据同步

    这里测试环境只搭建一台NFS服务器

    ​ 1)安装NFS服务(客户端只需安装NFS服务即可,用于客户端驱动NFS设备):yum install -y nfs-utils

    ​ 2)准备共享目录:mkdir -p /root/data/nfs

    ​ 3)将共享目录以读写权限暴露给192.168.248.0/24网段中的所有主机:vi /etc/exports

    ​ 添加 /root/data/nfs 192.168.248.0/24(rw,no_root_squash)

    ​ ps1:原来/etc/exports是空的

    ​ ps2:其中no_root_squash表示:NFS客户端连接服务端时如果使用的是root的话,那么对服务端共享目录也拥有root权限

    ​ 5)启动NFS服务:systemctl start nfs --》 systemctl enable nfs

    ​ 6)查看:exportfs -v
    在这里插入图片描述

    ​ 7)如果其他台也装nfs,可以将dnf服务器的存储路径挂载出去,共享挂载路径(可忽略):mount -t nfs 192.168.248.11:/root/data/nfs /root/data/nfs

  3. 实操逻辑

    1. 先声明一个NFS储存类型的volume,数据储存在远程主机的目录中
    2. 在一个Pod中准备两个容器nginx和busybox
    3. 将volume分别挂载到两个容器的目录中
    4. 然后nginx容器负责向volume中写日志,busybox中通过命令从volume读取日志文件内容到控制台
    
  4. 编写脚本:vi /opt/volume-nfs.yaml

    apiVersion: v1
    kind: Pod
    metadata:name: volume-nfs
    spec:containers:- name: nginximage: nginx:latestports:- name: nginx-portcontainerPort: 80protocol: TCPvolumeMounts:    # 将logs-volume挂载到nginx容器的/var/log/nginx目录, nginx会将用户的访问日志写入到该目录的access.log文件中- name: logs-volumemountPath: /var/log/nginx- name: busyboximage: busybox:latestcommand: ["/bin/sh", "-c", "tail -f /logs/access.log"] volumeMounts:    # 将logs-volume挂载到busybox容器中的/logs目录- name: logs-volume mountPath: /logsvolumes:    # 声明volume- name: logs-volumenfs:server: 192.168.248.10    # NFS服务器地址path: /root/data/nfs     # NFS服务器的共享目录readOnly: false    # 是否只读
    
  5. 启动:kubectl apply -f /opt/volume-nfs.yaml

  6. 查看pod:kubectl get pod volume-nfs -o wide
    在这里插入图片描述

  7. 访问Pod中的Nginx:curl 192.169.189.68

  8. 查看日志(-c是指定容器):kubectl logs volume-nfs -c busybox -f

  9. 查看文件:ls /root/data/nfs
    在这里插入图片描述

这篇关于14-k8s-基本存储之EmptyDir、HostPath、NFS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/222862

相关文章

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

SpringBoot整合MybatisPlus的基本应用指南

《SpringBoot整合MybatisPlus的基本应用指南》MyBatis-Plus,简称MP,是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,下面小编就来和大家介绍一下... 目录一、MyBATisPlus简介二、SpringBoot整合MybatisPlus1、创建数据库和

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

C语言中的浮点数存储详解

《C语言中的浮点数存储详解》:本文主要介绍C语言中的浮点数存储详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、首先明确一个概念2、接下来,讲解C语言中浮点型数存储的规则2.1、可以将上述公式分为两部分来看2.2、问:十进制小数0.5该如何存储?2.3 浮点

MySQL常见的存储引擎和区别说明

《MySQL常见的存储引擎和区别说明》MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY、Archive、CSV和Blackhole,每种引擎有其特点和适用场景,选择存储引擎时需根... 目录mysql常见的存储引擎和区别说明1. InnoDB2. MyISAM3. MEMORY4. A

Golang基于内存的键值存储缓存库go-cache

《Golang基于内存的键值存储缓存库go-cache》go-cache是一个内存中的key:valuestore/cache库,适用于单机应用程序,本文主要介绍了Golang基于内存的键值存储缓存库... 目录文档安装方法示例1示例2使用注意点优点缺点go-cache 和 Redis 缓存对比1)功能特性

Python中多线程和多进程的基本用法详解

《Python中多线程和多进程的基本用法详解》这篇文章介绍了Python中多线程和多进程的相关知识,包括并发编程的优势,多线程和多进程的概念、适用场景、示例代码,线程池和进程池的使用,以及如何选择合适... 目录引言一、并发编程的主要优势二、python的多线程(Threading)1. 什么是多线程?2.

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec