Kubernetes----HostPath类型的基本存储

简介: Kubernetes----HostPath类型的基本存储

一、HostPath简介

EmptyDir中的数据不会被持久化,它会随着Pod的结束而销毁,如果想简单的将数据持久化到主机中,可以选择HostPath

HostPath就是将Node主机中的一个实际目录挂载到Pod中,以供容器使用,这样的设计就可以保证Pod销毁了,但是数据可以存在Node主机上

二、HostPath实例演示

如下,将Node节点上一个目录挂载到pod中,这样当pod销毁时,数据仍然存在,即做到了持久化存储
在这里插入图片描述
编辑hostpath.yaml文件,内容如下:

apiVersion: v1
kind: Namespace
metadata:
  name: dev

---

apiVersion: v1
kind: Pod
metadata:
  name: volume-hostpath
  namespace: dev
spec:
  containers:
  - name: nginx
    image: nginx:1.17.1
    ports:
    - containerPort: 80
    volumeMounts:
    - name: logs-volume
      mountPath: /var/log/nginx
  - name: busybox
    image: busybox:1.30
    command: ["/bin/sh","-c","tail -f /logs/access.log"]
    volumeMounts:
    - name: logs-volume
      mountPath: /logs
  volumes:
  - name: logs-volume
    hostPath:
      path: /root/logs
      type: DirectoryOrCreate # 目录如果不存就创建

这里type字段的可选值如下:

DirectoryOrCreate       # 目录存在就使用,不存在就先创建再使用
Directory               # 目录必须存在
FileOrCreate            # 文件存在就使用,不存在就先创建再使用
File                    # 文件必须存在
Socket                  # unix套接字必须存在
CharDevice              # 字符设备必须存在
BlockDevice             # 块设备必须存在

然后使用如下命令创建

[root@master Volume]# kubectl apply -f hostpath.yaml
namespace/dev created
pod/volume-hostpath created
[root@master Volume]#

查看创建的资源

[root@master Volume]# kubectl get pod -n dev -o wide
NAME              READY   STATUS    RESTARTS   AGE     IP             NODE    NOMINATED NODE   READINESS GATES
volume-hostpath   2/2     Running   1          6m18s   10.244.1.248   node1   <none>           <none>
[root@master Volume]#

此时去node1节点发现已经创建了如下logs文件夹

[root@node1 ~]# ls /root/
anaconda-ks.cfg  logs  test.sh
[root@node1 ~]#

然后在node1节点上执行如下命令检测日志文件

tail -f /root/logs/access.log

然后去master节点连续执行三次如下请求nginx的命令

curl 10.244.1.248:80

再回到node1节点发现此时已经出现了如下打印

[root@node1 logs]# tail -f /root/logs/access.log
10.244.0.0 - - [07/Apr/2022:13:45:06 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"
10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"
10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"

此时,回到master节点,使用如下命令删除pod资源

[root@master Volume]# kubectl delete -f hostpath.yaml
namespace "dev" deleted
pod "volume-hostpath" deleted
[root@master Volume]#

此时,再次回到node1节点,发现此时 /root/logs/log.access.log文件依然存在,而且内容也未消失

[root@node1 logs]# ls /root/logs/
access.log  error.log
[root@node1 logs]# cat /root/logs/access.log
10.244.0.0 - - [07/Apr/2022:13:45:06 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"
10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"
10.244.0.0 - - [07/Apr/2022:13:45:08 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.29.0" "-"
[root@node1 logs]#
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
5月前
|
存储 Kubernetes 容器
Kubernetes 存储选项:持久化卷与存储类
【8月更文第29天】随着容器化的普及,越来越多的应用程序需要持久化数据以保持状态信息。Kubernetes 提供了一套完整的解决方案来管理和配置持久化存储,包括持久卷 (Persistent Volume, PV)、持久卷声明 (Persistent Volume Claim, PVC) 和存储类 (StorageClass)。本文将详细介绍这些概念,并通过实际示例来演示如何在 Kubernetes 中配置存储。
412 1
|
5月前
|
Kubernetes 监控 调度
在K8S中,DaemonSet类型资源特性?
在K8S中,DaemonSet类型资源特性?
|
5月前
|
存储 Kubernetes 容器
k8s创建NFS动态存储
k8s创建NFS动态存储
|
5月前
|
Kubernetes 负载均衡 网络协议
在K8S中,Service的类型有哪几种,请说⼀下他们的用途?
在K8S中,Service的类型有哪几种,请说⼀下他们的用途?
|
5月前
|
Kubernetes 负载均衡 网络协议
在k8S中,Servic类型有哪些?
在k8S中,Servic类型有哪些?
|
6月前
|
存储 Kubernetes 应用服务中间件
k8s使用rbd作为存储
k8s使用rbd作为存储
69 6
|
5月前
|
Prometheus Kubernetes 监控
在K8S中,DaemonSet类型的资源特性有哪些?
在K8S中,DaemonSet类型的资源特性有哪些?
|
5月前
|
Kubernetes 负载均衡 网络协议
在K8S中,Service的类型有哪些?
在K8S中,Service的类型有哪些?
|
5月前
|
存储 Kubernetes 网络协议
在K8S中,有哪几种控制器类型?
在K8S中,有哪几种控制器类型?
|
5月前
|
存储 Kubernetes 数据安全/隐私保护
在K8S中,如果后端nfs存储的ip发生变化如何解决?
在K8S中,如果后端nfs存储的ip发生变化如何解决?

热门文章

最新文章