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
    在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL逻辑架构

文章目录 逻辑架构剖析1. 连接层2. 服务层3. 引擎层4. 存储层 SQL执行流程1. MySQL中的 SQL执行流程(理论)2. MySQL8中的 SQL 执行流程(实践)确认profiling 是否开启多次执行相同SQL查询查看profiles查看profile 3. SQL语法顺序 数…

MFC-对话框

目录 1、模态和非模态对话框: (1)、对话框的创建 (2)、更改默认的对话框名称 (3)、创建模态对话框 1)、创建按钮跳转的界面 2)、在跳转的窗口添加类 3&#xff0…

Ceph 中的写入放大

新钛云服已累计为您分享769篇技术干货 介绍 Ceph 是一个开源的分布式存储系统,设计初衷是提供较好的性能、可靠性和可扩展性。 Ceph 独一无二地在一个统一的系统中同时提供了对象、块、和文件存储功能。 Ceph 消除了对系统单一中心节点的依赖,实现了无中…

Android自定义AppGlideModule,DataFetcher ,ModelLoaderFactory,ModelLoader,Kotlin(1)

Android自定义AppGlideModule,DataFetcher ,ModelLoaderFactory,ModelLoader,Kotlin(1) 假设实现一个简单的功能,对传入要加载的path路径增加一定的筛选、容错或“重定向”,需要自定义一个模型,基于这个模型,让Glide自动匹配模型…

C++前缀和算法:构造乘积矩阵

基础知识点 C算法:前缀和基础 题目 给你一个下标从 0 开始、大小为 n * m 的二维整数矩阵 grid ,定义一个下标从 0 开始、大小为 n * m 的的二维矩阵 p。如果满足以下条件,则称 p 为 grid 的 乘积矩阵 : 对于每个元素 p[i][j] …

Redis HyperLogLog的使用

Redis HyperLogLog知识总结 一、简介二、使用 一、简介 Redis HyperLogLog是一种数据结构,用于高效地计算基数(集合中唯一元素的数量)。它的主要作用是用于在内存中高效地存储和计算大量数据的基数,而无需完全存储所有的数据。Hy…

CICD:Circle CI 实现CICD

持续集成解决什么问题 提高软件质量效率迭代便捷部署快速交付、便于管理 持续集成(CI) 集成,就是一些孤立的事物或元素通过某种方式集中在一起,产生联系,从而构建一个有机整体的过程。 持续,就是指长期…

BIM轻量化技术简介

BIM轻量化技术是指在工程建筑的BIM模型建立之后(利用专业的BIM建模软件,比如Autodesk Revit, Bentley MicroStation, DS Catia等),通过对BIM模型的压缩处理等技术手段,让BIM可以在各类WEB浏览器、移动App上被使用的技术…

[架构之路-237]:目标系统 - 纵向分层 - 网络通信 - DNS的递归查询和迭代查询

目录 一、DNS协议与DNS系统架构 1.1 什么是DNS协议 1.2 为什么需要DNS协议 1.3 DNS系统架构 二、DNS系统的查询方式 2.1 递归与迭代的比较 2.2 DNS递归查询 2.3 DNS迭代查询 一、DNS协议与DNS系统架构 1.1 什么是DNS协议 DNS(Domain Name System&#xff…

2.3 初探Hadoop世界

文章目录 零、学习目标一、导入新课二、新课讲解(一)Hadoop的前世今生1、Google处理大数据三大技术2、Hadoop如何诞生3、Hadoop主要发展历程 (二)Hadoop的优势1、扩容能力强2、成本低3、高效率4、可靠性5、高容错性 (三…

数据分析案例-基于snownlp模型的MatePad11产品用户评论情感分析(文末送书)

🤵‍♂️ 个人主页:艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞&#x1f4…

Android 14 正式发布,已经在 AOSP 中上线

本心、输入输出、结果 文章目录 Android 14 正式发布,已经在 AOSP 中上线前言总结主要更新内容机型支持优化性能的数据体现字体放大、多媒体支持加强Android 14 增加了对 10 位高动态范围 (HDR) 图像的支持提供了新的图形和尺寸管理用户体验 与隐私安全弘扬爱国精神Android 14…

nvm、node、npm解决问题过程记录

在Windows10如何降级Node.js版本:可以尝试将Node.js版本降级到一个较旧的版本,以查看问题是否得以解决。可以使用Node Version Manager (nvm) 来轻松切换Node.js版本,具体完整步骤: 首先,需要安装Node Version Manager…

leetcode-62.不同路径

1. 题目 2. 解答 dp[i][j]表示机器人位于第i&#xff0c;j位置的时候&#xff0c;有多少路径 如果i 0&#xff0c;dp[i][j] 1;如果j 0&#xff0c;dp[i][j] 1;其他情况dp[i][j] dp[i-1][j] dp[i][j - 1] #include <stdio.h>int solve(int m, int n) {int dp[m][…

【python海洋专题二十】subplots_adjust布局调整

上期读取soda&#xff0c;并subplot 但是存在一些不完美&#xff0c;本期修饰 本期内容 subplots_adjust布局调整 1&#xff1a;未调整布局的 2&#xff1a;调整布局 往期推荐 【python海洋专题一】查看数据nc文件的属性并输出属性到txt文件 【python海洋专题二】读取水深…

微信小程序框架---视图层逻辑层API事件

目录 前言 一、小程序框架介绍 1.响应的数据绑定 2.页面管理 3.基础组件 4.丰富的 API 二、视图层 View 1.WXML 数据绑定 列表渲染 条件渲染 模板 2.WXSS 尺寸单位 样式导入 内联样式 选择器 全局样式与局部样式 3.WXS 示例 注意事项 页面渲染 数据处理 …

水滴怕片效果实现

效果展示 CSS 知识点 border-radius 属性运用 FANCY-BORDER-RADIUS 工具 此工具主要是实现不规则的图形。 FANCY-BORDER-RADIUS 工具地址 页面整体布局实现 <div class"container"><div class"drop" style"--clr: #ff0f5b">&l…

Python学习基础笔记六十六——对象的方法

我们已经学习到的对象类型&#xff1a; 整数类型的对象 字符串类型的对象 列表类型的对象 元组类型的对象 对象通常都有属于自己的方法&#xff08;method&#xff09; 调用对象的方法和调用函数差不多&#xff0c;只要在前面加上所属对象的一个点。 var1 [1, 2, 3,4, 5,…

PreScan与MATLAB联合仿真报错

一、 问题&#xff1a; Error:Matlab ||和&&运算符的操作数必须能够转换为逻辑标量值 二、解决办法 必须安装VS2013&#xff08;我装的VS2017不行的&#xff09;&#xff0c;然后重启prescan和MATLAB&#xff0c;编译通过&#xff0c;界面如下&#xff1a; 三、VS…

vue-element-admin—登录页面添加自定义背景

一、效果图 初始效果&#xff1a; 更改背景后效果&#xff1a; 二、操作步骤 1、准备图片 2、更改代码 打开下面路径的 index.vue 文件&#xff1a; vue-element-admin-master\src\views\login\index.vue 也就是登录页面。 对 .login-container 样式代码块内代码做如下…