Kubernetes volume数据卷
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,Volume是kubernetes Pod中多个容器访问的共享目录Kubernetes提供了众多的volume类型,包括:emptyDir、hostPath、NFS、GlusterFS、configM
千家信息网最后更新 2025年12月01日Kubernetes volume数据卷
Volume是kubernetes Pod中多个容器访问的共享目录
Kubernetes提供了众多的volume类型,包括:emptyDir、hostPath、NFS、GlusterFS、configMap、Cephfs
1、emptyDir
emptyDir类型的vloume在Pod分配到node上时被创建,kubernetes会在node上自动分配一个目录,所以无须指定宿主机node上对应的目录文件,该目录初始化内容为空,当Pod从node上被移除时,emptyDir中的数据会被永久删除
1.编辑emptyDir.yaml文件
apiVersion: extensions/v1beta1kind: Deploymentmetadata: name: web-demo-emptyspec: replicas: 2 selector: matchLabels: app: app-demo-empty template: metadata: labels: app: app-demo-empty spec: containers: - name: tomcat-demo image: tomcat imagePullPolicy: IfNotPresent ports: - containerPort: 8080 volumeMounts: # 将/mydata-data目录挂载到共享仓库 - mountPath: /mydata-data name: datavol - name: nginx-demo image: nginx imagePullPolicy: IfNotPresent ports: - containerPort: 80 volumeMounts: # 将/mydata-data目录挂载到共享仓库 - mountPath: /mydata-data name: datavol # emptyDir是一个共享仓库(中央仓库) volumes: - name: datavol emptyDir: {}2.执行kubectl create
$ kubectl create -f emptyDir.yamldeployment.extensions/web-demo-empty created3.先进入tomcat-demo容器中创建文件
$ kubectl exec -it web-demo-empty-9b5644c45-7bpn5 -c tomcat-demo bash$ touch /mydata-data/data.txt$ ls /mydata-data/data.txt4.在进入nginx-demo容器查看是否存在data.txt文件
$ kubectl exec -it web-demo-empty-9b5644c45-7bpn5 -c nginx-demo bash$ ls /mydata-data/data.txt经过试验证明emptyDir是一个共享空目录,可以让Pod中的多个容器之间共享该目录
2、hostPath
hostPath类型的vloume为Pod挂载到宿主机上的目录或文件,使得容器可以使用宿主机的文件系统进行存储,但是在kubernetes中,Pod都是基于schedule组件来动态调度在不同的node节点上,当一个Pod在当前node节点上启动并通过hostPath存储了文件到本地后,下次在调度另外一个节点上启动时,就无法使用之前节点上存储的文件了。
1.编辑hostPath.yaml文件
apiVersion: extensions/v1beta1kind: Deploymentmetadata: name: web-demo-hostpathspec: replicas: 2 selector: matchLabels: app: app-demo-hostpath template: metadata: labels: app: app-demo-hostpath spec: containers: containers: - name: nginx-demo image: nginx imagePullPolicy: IfNotPresent ports: - containerPort: 80 volumeMounts: - mountPath: /mydata-data name: datavol volumes: - name: datavol hostPath: path: "/data"2.执行kubectl create
$ kubectl create -f hostPath.yamldeployment.extensions/web-demo-hostpath created3.需要在每个node节点创建/data目录,并创建测试文件
$ mkdir /data $ touch /data/test.txt4.进入容器里查看是否将/mydata-data挂载到了宿主机上
$ kubectl exec -it web-demo-hostpath-7866c644c4-7f8fk bash$ ls /mydata-data/test.txt
文件
目录
容器
节点
仓库
宿主
类型
存储
多个
宿主机
分配
调度
数据
不同
中央
之间
内容
动态
是在
空目录
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
乐陵软件开发定做
江苏网络营销软件开发价格
同名数据库已经存在
篡改数据库
河南企业软件开发机构
宝山区正规软件开发优化价格
计算机分类为服务器和啥
端口18090是应用还是数据库
珠海聊天软件开发定制
uml数据库通过什么打开
软件开发载体
全国游艺游戏设备数据库网站
网络安全与执法专业是公安类吗
sql 数据库太大 收缩
360安全网络安全诊断
东城区网络技术服务需求
高中学生网络安全培训内容
魔兽pvp和普通服务器
怎样攻击别人服务器
深圳安泰证券软件开发招聘
关于网络安全的行政法
服务器域名泛解析设置
享游网络技术
重庆忠县果蔬配送软件开发
怎么用db2建立数据库
服务器怎么有效销售管理制度
酷播服务器配置
安装数据库出现服务器不兼容
ftp服务器怎么上传
邮箱代理服务器怎么使用