​Kubernetes CSI Snapshot(下篇)

目标目前在Kuberentes中,卷插件仅支持配置空的存储卷。随着新的存储功能(包括卷快照和卷克隆)的提出,因此需要支持配置卷时数据填充以。例如,可以从快照源创建卷,也可以从其他卷源克隆卷。根据创建卷的来源,有两种情况:

1、卷配置程序可以识别数据源并能够直接从数据源创建卷(例如,将快照还原到卷或克隆卷)。

2、卷配置程序无法识别数据源,并创建空存储卷。另一个外部组件(数据填充程序)可以监视卷创建并可以将数据填充/导入到已配置的卷。只有在将数据填充到卷后,PVC才可以被使用。

考虑到可以有许多不同类型的数据源用于将数据填充到卷中,因此我们建议在PersistentVolumeClaimSpec中添加一个通用的“DataSource”字段来表示不同类型的数据源。

PVC API 变化我们将在PVC中添加DataSource字段,以表示预先填充到预配置卷的数据源。对于DataSource字段,我们定义一个新类型“TypedLocalObjectReference”。它类似于具有附加Kind字段的“LocalObjectReference”类型,以便支持多种数据源类型。在alpha版本中,此数据源应和PVC位于同一命名空间。此数据源受限于PVC的同一名称空间。

设计细节在第一个alpha版本中,我们仅支持来自Snapshot的数据源。因此,DataSource中的Kind必须是“VolumeSnapshot”。在这种情况下,provisioner 应该在一个步骤中完成配置卷并填充数据。目前我们还不需要外部数据填充程序。

对于需要外部数据填充程序的其他类型的数据源,卷创建和数据填充是两个单独的步骤。 只有在数据准备就绪时,才能将PVC / PV标记为就绪(绑定),用户可以开始使用它们。我们正在制定一个单独的提案,使用“Pod Ready ++”(https://github.com/kubernetes/community/blob/master/keps/sig-network/0007-pod-ready%2B%2B.md)中的类似想法来解决这个问题。

注意:为了使用此数据源功能,用户/管理员需要更新到可以识别快照数据源的新external provisioner。否则,将忽略数据源并创建空存储卷。

示例本示例基于kubernetes 1.12版本启动的local-up环境,使用csi-hostpath作为测试插件,来演示snapshot的创建以及从snapshot还原数据卷。示例所使用的yaml可在https://github.com/wackxu/csi-snapshot-test找到。

步骤一:下载kubernetes 1.12版本,修改hack/local-up-cluster.sh脚本,如下:

第26行修改如下,允许以特权形式启动container。

第131行添加下列,开启VolumeSnapshotDataSource特性开关。

然后我们就可以启动local-up集群。

步骤二:部署external-provisioner、external-snapshotter、external-attacher、driver-registrar、hostpathplugin等sidecar容器。部署脚本包含serviceaccount、clusterrole等所需要的全部资源。

查看csi-pod,容器全部处于运行状态。

步骤三:创建storageClass,以及pvc,查看pvc以及创建的pv状态,均已处于bound状态。

步骤四:创建pod,使用pv,同时往pv中写入数据。

步骤五:创建volumeSnapshotClass,然后对csi-pvc创建snapshot

查看创建的volumeSnapshotContent具体信息。

验证snapshot是否创建成功。

步骤六:创建csi-restore-pvc,添加我们此前创建的snapshot为数据源。

查看pvc,pv状态

查看pv详细信息,volumeHandle为93119a08-b754-11e8-97ca-0242ac110003,

验证pv数据是否预填充,我们可以看到创建出来的pv,已有数据填充。

相关服务请访问:https://support.huaweicloud.com/cce/index.html?utm_content=cce_helpcenter_2019

K8S 1.12大特性最快最深度解析:Kubernetes CSI Snapshot(下)的更多相关文章

  1. K8S 1.12大特性最快最深度解析:Kubernetes CSI Snapshot(上)

    ​ 背景 许多存储系统提供了创建存储卷“快照”(snapshot)的能力,以防止数据丢失.快照可以替代传统的备份系统来备份和还原主要数据和关键数据.快照能够快速备份数据(例如,创建GCE PD快照仅需 ...

  2. HTML5在移动端开发的12大特性

    1.离线缓存为HTML5开发移动应用提供了基础 HTML5 Web Storage API可以看做是加强版的cookie,不受数据大小限制,有更好的弹性以及架构,可以将数据写入到本机的ROM中,还可以 ...

  3. 有了这 4 大特性,CDN 好用到飞起

    随着 CDN 市场的快速发展和网络新技术的不断涌现,目前的 CDN 已不仅仅是当初简单的内容分发,同时也是新特性研发.新技术推广及实践的平台.这些新技术.新特性,或者能够保障 CDN 安全性,或是提升 ...

  4. 前端开发者不得不知的es6十大特性(转)

    转载自AlloyTeam:http://www.alloyteam.com/2016/03/es6-front-end-developers-will-have-to-know-the-top-ten ...

  5. 不得不知的ES6十大特性

    ES6(ECMAScript2015)的出现,无疑给前端开发人员带来了新的惊喜,它包含了一些很棒的新特性,可以更加方便的实现很多复杂的操作,提高开发人员的效率. 本文主要针对ES6做一个简要介绍. 主 ...

  6. jdk8十大特性并代码demo(转)

    一.十大特性 1.Lambda表达式 2.Stream函数式操作流元素集合 3.接口新增:默认方法与静态方法 4.方法引用,与Lambda表达式联合使用 5.引入重复注解 6.类型注解 7.最新的Da ...

  7. ES6十大特性

    本文主要针对ES6做一个简要介绍. 主要译自:  http://webapplog.com/ES6/comment-page-1/.也许你还不知道ES6是什么, 实际上, 它是一种新的javascri ...

  8. AngularJS-chapter1-2-四大特性

    4大特性 MVC MVC实例  数据模型,控制器,视图 HelloAngular_MVC.html 图中的 ng-controller="HelloAngular"  定义了Hel ...

  9. UFT\QTP 12 新特性

    UFT\QTP 12 新特性 http://blog.csdn.net/testing_is_believing/article/details/22310297

随机推荐

  1. 随机图片大小在DIV中垂直居中对齐总结

    老遇到这种样式 现在总结一下 <!DOCTYPE> <html> <head> <meta http-equiv="Content-Type&quo ...

  2. 英雄联盟测试静态IP(固态IP)和动态IP的网速测试

    在自己家里测试的,平时用迅雷下载大约600KB/S.同时,设置成动态IP的话,英雄联盟的延迟大约在100ms左右,如果设置成静态IP的话,大约是50ms左右,不过也有可能和DNS服务器的设置成静态有关 ...

  3. 利用sourceinsight宏(Quicker.em)提高编码效率和质量

    利用sourceinsight宏(Quicker.em)提高编码效率和质量Marco是sourceinsight软件一个强大的功能,用户可以通过编写宏来实现自定义功能.这里有个比较流行的宏文件quic ...

  4. 虚拟机中windows下制作超级隐藏账户

    这篇博客非原创,我只是将很多大佬写的东西理解了一下写了出来. 接下来的实验最好在虚拟机进行,因为可以快照~ 制作隐藏用户可以说是两种方法但是基本操作一样,所以我们穿插着进行一种是隐藏账户,一种是影子账 ...

  5. python 之 logger日志 字典配置文件

    import os import logging.config #不能只导入logging BASE_DIR=os.path.dirname(os.path.dirname(__file__)) # ...

  6. JS实现可用滑块滑动的缓动图

    尝试模仿京东的"发现好货"模块的可用滑块滑动的缓动图 JS代码 function $(id) { return document.getElementById(id); } //缓 ...

  7. TZOJ3114: {A}∩{B}

    #include<stdio.h> int main() { ],b[],m,i,j,c; scanf("%d",&t); while(t--) { c=; s ...

  8. Hibernate定义

    Hibernate:(Object Relational Mapping)对象关系映射   对象关系映射就是在操作数据库之前,先将数据库的表和实体类关联起来,通过实体类的对象,就可以操作数据库,开发人 ...

  9. vue-cli3+mand-mobile svg 配置

    // vue.config.js chainWebpack: config => { config.resolve.alias // key,value自行定义,比如.set('@assets' ...

  10. javascript之new操作符

    new 运算符做了哪些事情 1.新生成了一个对象 2.链接到原型 3.绑定 this 4.返回新对象 自己实现一个 new function create() { // 创建一个空的对象 let ob ...