#Volume

Volume 解决数据持久化和容器间共享数据

Kubernetes支持几十种类型的后端存储卷

hostPath挂载实例,挂载Node节点/tmp/test-volume目录到容器/test-pd

#volume-test.yaml
apiVersion: v1
kind: Pod
metadata:
name: volume-test
spec:
containers:
- image: alivv/nginx:node
name: volume-test
volumeMounts:
- mountPath: /test-pd
name: test-volume
volumes:
- name: test-volume
hostPath:
path: /tmp/test-volume
type: DirectoryOrCreate #node节点不存在则创建空目录
#创建pod
kubectl create -f volume-test.yaml #查看pod所在node节点
kubectl get pod volume-test -o wide
#在容器里创建文件
kubectl exec -it volume-test -- sh -c "date >/test-pd/txt" #删除pod
kubectl delete -f volume-test.yaml #在node节点检查文件存在
cat /tmp/test-volume/txt

hostPath type类型Directory、File、Socket等

参考 https://feisky.gitbooks.io/kubernetes/concepts/volume.html

#PV PVC

  • PV PersistentVolume 持久卷,作为存储资源,包含存储实现细节

  • PVC PersistentVolumeClaim 用户存储的请求,Pod消耗节点资源

#使用NFS后端存储,创建PV、PVC、Pod实例

#创建nfs存储

#NFS服务端 (centos7)
yum install nfs-utils rpcbind -y
mkdir -p /data/nfs/{download,bakup,www}
echo "/data/nfs *(rw,no_root_squash,sync)">>/etc/exports
exportfs -r
systemctl enable rpcbind nfs-server
systemctl restart rpcbind nfs-server
showmount -e localhost #NFS客户端(Node节点)
yum install nfs-utils rpcbind -y
systemctl start rpcbind
systemctl enable rpcbind

#创建PV

#pv1-demo.yaml
apiVersion: v1
kind: PersistentVolume
metadata:
name: pv1
spec:
capacity: #存储能力
storage: 10Gi
accessModes:
- ReadWriteMany #读写权限,多节点挂载
persistentVolumeReclaimPolicy: Retain #回收策略 保留数据
nfs:
path: /data/nfs
server: 172.16.11.141
#创建pv
kubectl create -f pv1-demo.yaml
#查看
kubectl get pv

创建PVC

#pvc-nfs-demo.yaml
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: pvc-nfs
spec:
accessModes:
- ReadWriteMany
resources:
requests:
storage: 1Gi

kubectl create -f pvc-nfs-demo.yaml
kubectl get pvc
kubectl get pv

部署Pod使用pvc实例

#nfs-pvc-deploy.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: nfs-pvc
spec:
replicas: 3
template:
metadata:
labels:
app: nfs-pvc
spec:
containers:
- name: nginx
image: alivv/nginx:node
imagePullPolicy: IfNotPresent
ports:
- containerPort: 80
name: web
#使用volume
volumeMounts:
- name: www
subPath: nginx-pvc #远程子路径
mountPath: /usr/share/nginx/html
volumes:
- name: www
persistentVolumeClaim:
claimName: pvc-nfs
#部署Pod使用pvc实例
kubectl apply -f nfs-pvc-deploy.yaml
#查看
kubectl get pod
#NFS节点写入index.html文件
echo nfs pvs test $(date +"%F %T") |tee /data/nfs/nginx-pvc/index.html #查看Pod ip
kubectl get pod -o wide #访问Pod ip,查看内容为NFS节点写入内容
kubectl get pod -o wide |awk '/nfs-pvc/{print "curl "$6}'
kubectl get pod -o wide |awk '/nfs-pvc/{print "curl "$6}' |sh
#删除demo
kubectl delete -f nfs-pvc-deploy.yaml
kubectl delete -f pvc-nfs-demo.yaml
kubectl delete -f pv1-demo.yaml

Blog地址 https://www.cnblogs.com/elvi/p/11755813.html

本文git地址 https://gitee.com/almi/k8s/tree/master/notes

6.k8s.存储Volume.PV.PVC的更多相关文章

  1. k8s系列---存储卷pv/pvc。configMap/secert

    因为pod是有生命周期的,pod一重启,里面的数据就没了.所以我们需要数据持久化存储. 在k8s中,存储卷不属于容器,而是属于pod.也就是说同一个pod中的容器可以共享一个存储卷. 存储卷可以是宿主 ...

  2. 8.1 k8s使用PV/PVC做数据持久化运行redis服务,数据保存至NFS

    1.制作redis docker镜像 1.1 准备alpine基础镜像 # 下载 docker pull alpine:3.13 # 更改tag docker tag alpine:3.13 192. ...

  3. 4.k8s存储之Volume、PV、PVC和StatefulSet

    3.Volume 容器磁盘上的文件的生命周期是短暂的,这就使得在容器中运行重要应用时会出现一些问题.首先,当容器崩溃时,kubelet 会重启它,但是容器中的文件将丢失--容器以干净的状态(镜像最初的 ...

  4. k8s的持久化存储PV&&PVC

    1.PV和PVC的引入 Volume 提供了非常好的数据持久化方案,不过在可管理性上还有不足. 拿前面 AWS EBS 的例子来说,要使用 Volume,Pod 必须事先知道如下信息: 当前 Volu ...

  5. K8S系列第九篇(持久化存储,emptyDir、hostPath、PV/PVC)

    更多k8s内容,请关注威信公众好:新猿技术生态圈 一.数据持久化 Pod是由容器组成的,而容器宕机或停止之后,数据就随之丢了,那么这也就意味着我们在做Kubernetes集群的时候就不得不考虑存储的问 ...

  6. k8s存储 pv pvc ,storageclass

    1.  pv  pvc 现在测试 glusterfs  nfs  可读可写, 多个pod绑定到同一个pvc上,可读可写. 2. storageclass  分成两种 (1)  建立pvc, 相当于多个 ...

  7. k8s-数据持久化存储卷,nfs,pv/pvc

    目录 数据持久化-储存卷 官方文档 存储卷类型 1.emptyDir 2.hostpath 3.pv/pvc(推荐使用) nfs官方文档 安装测试nfs pv/pvc管理nfs 官方文档 pv/pvc ...

  8. k8s入门之PV和PVC(八)

    某些应用是要持久化数据的,如果直接持久化在pod所在节点,当pod因为某种原因重建或被调度另外一台节点,是无法访问到之前持久化的数据,所以需要一个公共存储数据的地方,无论pod删除重建或重新调度到其他 ...

  9. Kubernetes 存储卷管理 PV&PVC(十)

    目录 一.emptyDir 二.hostPath 三.PV & PVC 1.NFS PersistentVolume 2.创建 PVC 3.创建 Pod 进行挂载 为了持久化保存容器的数据,可 ...

随机推荐

  1. excle 文件的导入和导出

    //excle 文件导出 public function excel(){ try{ include(BASE_PATH."Excel/PHPExcel.php"); // ech ...

  2. Gcd HDU - 6545 (基础数论)

    wls 有一个整数 n,他想将 1 − n 这 n 个数字分成两组,每一组至少有一个数,并且使得两组数字的和的最大公约数最大,请输出最大的最大公约数. Input 输入一行一个整数 n. 2 ≤ n ...

  3. 2019.9.16:java课后测验

    一.动手动脑 1. 枚举类型是引用类型, 枚举不属于原始数据类型,它的每个具体值都引用一个特定的对象.相同的值则引用同一个对象. 可以使用“==”和equals()方法直接比对枚举变量的值,换句话说, ...

  4. 【NOIP2017模拟6.25】小W的动漫

    题目 小W最近迷上了日本动漫,每天都有无数部动漫的更新等着他去看,所以他必须将所有的动漫排个顺序,当然,虽然有无数部动漫,但除了1号动漫,每部动漫都有且仅有一部动漫是它的前传(父亲),也就是说,所有的 ...

  5. 获取树莓派ip地址的方法

    1.有显示器​ (1)鼠标停留在屏幕右上角网络图标上,2-3秒会显示网络连接信息​(2) 图形界面下打开终端运行ifconfig命令 2.登录路由器​查看名叫raspberry的设备 3.电脑上运行命 ...

  6. 【mysql】全文索引match多列报错

    表结构如下: CREATE TABLE `T` ( .... FULLTEXT KEY `title_fc` (`titleindex`), FULLTEXT KEY `shortname_fc` ( ...

  7. css-js-弹出层

    HTML: <!-- 弹出层 --> <div class="popwindow" > <div class="pop" id=& ...

  8. eclipse中使用maven搭建多模块项目

    暂时参考:https://blog.csdn.net/u012343297/article/details/79883870

  9. Codeforces 1203F1 Complete the Projects (easy version)

    cf题面 Time limit 2000 ms Memory limit 262144 kB 解题思路 看见这题觉得贪心可做,那就贪吧.(昨天真是贪心的一天,凌晨才被这两道贪心题虐,下午多校又来,感觉 ...

  10. macOS 更新 git 命令提示 xcrun,.gitignore 配置不生效问题。

    macOS 更新 运行git提示xcrun: error: invalid active developer path 在终端输入 xcode-select --install 即可以解决该问题 .g ...