设为首页 收藏本站
查看: 1733|回复: 0

[经验分享] Docker实践(3)—浅析device mapper的thin provision

[复制链接]

尚未签到

发表于 2015-4-17 10:33:57 | 显示全部楼层 |阅读模式
  thin provision是在 kernel3.2 中引入的。它主要有以下一些特点:
  (1)允许多个虚拟设备存储在相同的数据卷中,从而达到共享数据,节省空间的目的;
  (2)支持任意深度的快照。之前的实现的性能为O(n),新的实现通过一个单独的数据避免了性能随快照深度的增加而降低。
  (3)支持元数据存储到单独的设备上。这样就可以将元数据放到镜像设备或者更快的SSD上。
  上面3个特性正是devicemapper支持docker存储镜像的关键特性。
  
使用lvm管理thin provisioning
  # dd if=/dev/zero of=lvm0.img bs=1024k count=256
  # losetup /dev/loop7 lvm0.img
  # losetup -a
  /dev/loop0: [fd00]:786725 (/dev/loop0)
  /dev/loop1: [fd00]:786726 (/dev/loop1)
  /dev/loop7: [fd00]:420986 (/root/lvm/lvm0.img)
  
  # pvcreate /dev/loop7
    Physical volume "/dev/loop7" successfully created
  # vgcreate vg_test /dev/loop7
    Volume group "vg_test" successfully created
  
  在volume group中创建一个thin pool,大小为200M:
  # lvcreate -L 200M -T vg_test/mythinpool
    Logical volume "lvol0" created
    Logical volume "mythinpool" created
  
  # ls /dev/mapper/* |grep mythin
  /dev/mapper/vg_test-mythinpool
  /dev/mapper/vg_test-mythinpool_tdata
  /dev/mapper/vg_test-mythinpool_tmeta
  /dev/mapper/vg_test-mythinpool-tpool
  
  创建thin logical volume:
  # lvcreate -T vg_test/mythinpool -V 300M -n lvol1
    Logical volume "lvol1" created
  虽然thin pool只有200M,却可以创建300M的逻辑卷。
  # lvs
    LV         VG      Attr       LSize   Pool       Origin Data%  Move Log Cpy%Sync Convert
    lvol1      vg_test Vwi-a-tz-- 300.00m mythinpool          0.00                          
    mythinpool vg_test twi-a-tz-- 200.00m                     0.00     
  
  创建快照:
  # lvcreate -s --name mysnapshot1 vg_test/lvol1
    Logical volume "mysnapshot1" created
  
使用dmsetup管理thin provisioning
  创建thin pool

    dmsetup create pool \
       --table "0 20971520 thin-pool $metadata_dev $data_dev \
               $data_block_size $low_water_mark"
  
  # dmsetup create yy_thin_pool --table '0 409600 thin-pool /dev/loop6 /dev/loop7 128 0'
  # dmsetup table /dev/mapper/yy_thin_pool
  0 409600 thin-pool 7:6 7:7 128 0 0
  # dmsetup remove yy_thin_pool
  
  创建thinly-provisioned volume
  首先,必须发送消息给pool:

dmsetup message /dev/mapper/yy_thin_pool 0 "create_thin 0"
  这里的”0”是卷标识符,24位的数字,由调用者进行分配,如果已经存,会返回-EEXIST错误。
  
  使用thinly-provisioned volume
  创建一个20M大小的volume

dmsetup create thin --table "0 40960 thin /dev/mapper/yy_thin_pool 0"
  # dmsetup table /dev/mapper/thin
  0 40960 thin 253:3 0
  #mkfs.ext4 /dev/mapper/thin
  #mount /dev/mapper/thin /mnt/share1
  /dev/mapper/thin       20M  1.2M   18M   7% /mnt/share1
  
  Internal snapshots
  创建快照
  对一个active的卷创建快照,先要suspend volume。

dmsetup suspend /dev/mapper/thin
dmsetup message /dev/mapper/yy_thin_pool 0 "create_snap 1 0"
dmsetup resume /dev/mapper/thin
dmsetup create snap --table "0 40960 thin /dev/mapper/yy_thin_pool 1"
  红色部分是快照的名称。
  
  删除volume

dmsetup remove thin
dmsetup message /dev/mapper/yy_thin_pool 0 "delete 0"
  
docker的结构
  docker内部的存储结构大概如下:
DSC0000.png
  docker在初始化过程中,会创建一个100G的用于存储数据,和一个2G的用于存储元数据的稀疏文件,然后分别附加到回环块设备/dev/loop0和/dev/loop1。然后基于回环块设备创建thin pool。
  
DSC0001.png
DSC0002.png
  docker在创建image,会将image的信息(struct DevInfo)写到文件/var/lib/docker/devicemapper/metadata/$id,参考函数(devices *DeviceSet) registerDevice。
  
  主要参考
  [1]https://www.kernel.org/doc/Documentation/device-mapper/thin-provisioning.txt

作者:YY哥
出处:http://www.iyunv.com/hustcat/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-58075-1-1.html 上篇帖子: 转:shipyard : docker web UI 下篇帖子: docker解决数据存储问题的方案
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表