RHEL7snapshot快照原理及实验

简介:

RHEL7snapshot快照原理及实验

LVMlv提供了快照“snapshot”备份功能,这种功能也只对LVM 有效。snapshot有多种实现方法,这里只谈谈写时复制COW”,不是奶牛哦,是“Copy-On-Write”

 当一个snapshot创建的时候,仅拷贝原始卷里的源数据,这不是物理上的数据拷贝,因此snapshot的创建特别快,当原始卷里的数据有写入时,备份卷开始记录原始卷哪些数据发生了变化,然后在原始卷新数据覆盖旧数据时,将旧数据拷贝到snapshot的预留空间里,起到备份数据的作用,就保证了所有数据和创建备份卷之前的数据一致性。

 而对于snapshot的读操作,如果是读取数据块是没有修改过的,那么会将读操作直接重定向到原始卷上,如果是要读取已经修改过的块,那么就读取拷贝到snapshot中的块。所以当原始卷破坏了之后还能用snapshot备份的数据还原。

 参考一份51CTOasram先生】的解释吧:

 【镜像分离,是为了让镜像卷保持拆分一瞬间的状态,而不再继续被写入数据。而拆分之后,主卷所做的所有写IO动作,会以bitmap的方式记录下来。bitmap就是一份位图文件,文件中每个位都表示卷上的一个块(扇区,或者由多个扇区组成的逻辑块),如果这个块在镜像分离之后,被写入了数据,则程序就将 bitmap文件中对应的位从0变成1。待备份完成之后,可以将镜像关系恢复,此时主卷和镜像卷上的数据是不一致的,需要重新做同步。程序搜索 bitmap中所有为1的位,对应到卷上的块,然后将这些块上的数据,同步到镜像卷,从而恢复实时镜像关系。

改变块(changed block)

        快照创建成功后,源和快照共享同一份物理数据拷贝,直到数据发生写操作,此时源上老数据或者新增数据将被写向新的存储空间。为了记录和追踪块的变化和复制信息,需要一个位图(bitmap),它用于确定实际拷贝数据的位置,以及确定从源还是目标来获取数据。

并发(concurrent)

 它与改变块非常相似,但它总是物理地拷贝数据。当即时拷贝执行时,没有数据被复制。取而代之,它创建一个位图来记录数据的复制情况,并在后台进行真正的数据物理复制。

 写时复制快照在快照时间点之后,没有物理数据复制发生,仅仅复制了原始数据物理位置的元数据。因此,快照创建非常快,可以瞬间完成。然后,快照副本跟踪原始卷的数据变化(即原始卷写操作),一旦原始卷数据块发生写操作,则先将原始卷数据块读出并写入快照卷,然后用新数据块覆盖原始卷。这样我们访问快照卷上的数据仍旧是写操作前的,可以保证我们备份数据的一致性。】

 

检验一下snapshot的特点吧:

采取COW实现方式时,snapshot的大小并不需要和原始卷一样大。那设置成多大呢?第一、根据原始卷数据的改变大小范围来设置;第二、根据原始卷数据的更新频率来定。一旦 snapshot的空间记录满了原始卷块变换的信息,那么这个snapshot就无法使用了。当然,如果你的snapshot大小和原始卷一样大,甚至还要大,那snapshot备份就绝对的不会崩溃啦。

 

下面就开始吧!

一、新建lv分区,装上一个系统(可以不用装,其实这里只需要说明他是一个我们要备份的数据卷而已)

--->先查看一下vg空闲空间吧

[root@desktop21/]# vgs

  VG   #PV#LV #SN Attr   VSize  VFree

  vol0   2   4   1 wz--n-55.22g 26.22g

--->还有26.22G,建一个3Glv来装系统吧,lv名称syslv

[root@desktop21/]# lvcreate -L 3G -n syslv vol0

  Logical volume "syslv" created

[root@desktop21/]# lvdisplay /dev/vol0/syslv

  --- Logical volume ---

  LV Name                /dev/vol0/syslv

  VG Name                vol0

  LV UUID                xQXHqK-N3Oj-y9Z1-TBU6-hAsI-ek3V-PkmVmL

  LV Write Access        read/write

  LV Status              available

  # open                 0

  LV Size                3.00 GiB lv大小3G

  Current LE             96

  Segments               1

  Allocation             inherit

  Read ahead sectors     auto

  - currently set to     256

  Block device           253:6

--->ok,创建成功,接下来我就装一个linux的简易版吧,我就不上图了,自己要测试的自己去试试

【注意:这个lv建立起来若作为安装系统用的话就一定不能格式化了,它是作为硬盘用了哦,谁见过把硬盘拿来格式化了在装系统的?他会警告无法识别的硬盘~】

 

二、创建snapshot

终于装好了,我们来创建一个snapshot备份吧,和lv创建方法差不多,就多加一个参数-s

[root@desktop21/]# lvcreate -s -n snapsyslv -L 50M /dev/vol0/syslv

  Rounding up size to full physical extent 64.00MiB

  Logical volume "snapsyslv" created

[root@desktop21/]# lvdisplay /dev/vol0/snapsyslv

  --- Logical volume ---

  LV Name                /dev/vol0/snapsyslv

  VG Name                vol0

  LV UUID                snoXql-gI1Q-TSsF-F3LN-SyRI-HInY-8cZM3r

  LV Write Access        read/write

  LV snapshot status     active destination for /dev/vol0/syslv

  LV Status              available

  # open                 0

  LV Size                3.00 GiB

  Current LE             96

  COW-table size         64.00 MiB  (我的PE32M,创建的只能是32的倍数)

  COW-table LE           2

  Allocated to snapshot  0.03%  (使用率为0.03%

  Snapshot chunk size    4.00 KiB

  Segments               1

  Allocation             inherit

  Read aheadsectors     auto

  - currently set to     256

  Block device           253:7

--->oksnapsyslv创建好了,64M,查看一下snapsyslv的详细信息吧:

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 swi-a- 64.00m syslv    0.07                      

--->我们需要关心的就是上面的使用率0.07%,达到100%就释放,snapshot就坏了,就没用了。

 

三、改变原始卷的数据,查看备份卷的变化

1、登录到syslv所在的系统,新建文件测试

desktop64login: root

Password

[root@desktop64~]# dd if=/dev/zero of=testfile bs=1M count=20

20+0records in

20+0records out

20971520bytes (21 MB) copied, 0.0329396 s, 637 MB/s

--->好了,到我们的机子上看看快照的变化吧,刷新几下看看

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 swi-a- 64.00m syslv    0.07     

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 swi-a- 64.00m syslv   33.81                      

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 swi-a- 64.00m syslv   33.83                       

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 swi-a- 64.00m syslv   33.83

--->看到吗?使用率为33.83%了,快照大小为64M,原始卷新建20M的文件,看是不是使用率为33%左右呢?^_^

2、新建大小为50M的吧,加上之前的20M,看看快照的变化呢

[root@desktop64~]# dd if=/dev/zero of=testfile bs=1M count=50

50+0records in

50+0records out

52428800bytes (52 MB) copied, 0.132893 s, 395 MB/s

--->刷新一下,看看快照变化吧

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 Swi-I- 64.00m syslv  100.00                      

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 Swi-I- 64.00m syslv  100.00                      

[root@desktop21/]# lvs /dev/vol0/snapsyslv

  LV       VG   Attr   LSize Origin Snap%  Move Log Copy%  Convert

  snapsyslv vol0 Swi-I- 64.00m syslv  100.00

--->100%啦,查看一下快照的状态?

[root@desktop21/]# lvdisplay /dev/vol0/snapsyslv

  --- Logical volume ---

  LV Name                /dev/vol0/snapsyslv

  VG Name                vol0

  LV UUID                snoXql-gI1Q-TSsF-F3LN-SyRI-HInY-8cZM3r

  LV Write Access        read/write

  LV snapshot status     INACTIVE destination for /dev/vol0/syslv (挂了)

  LV Status              available

  # open                 0

  LV Size                3.00 GiB

  Current LE             96

  COW-table size         64.00 MiB

  COW-table LE           2

  Snapshot chunk size    4.00 KiB

  Segments               1

  Allocation             inherit

  Read ahead sectors     auto

  - currently set to     256

  Block device           253:7

--->看到吗,INACTIVE(没激活了),我们把它激活看看

[root@desktop21/]# lvchange -ay /dev/vol0/snapsyslv

  Can't change snapshot logical volume "snapsyslv"

--->Can't,不能激活了,快照不能用了哦,把它移除吧

[root@desktop21/]# lvremove /dev/vol0/snapsyslv

Doyou really want to remove active logical volume snapsyslv? [y/n]: y

  Logical volume "snapsyslv" successfullyremoved

--->ok,已经移除了,现在可以再继续创建快照了额^_^





      本文转自rshare 51CTO博客,原文链接:http://blog.51cto.com/1364952/1980061 ,如需转载请自行联系原作者




相关文章
|
5月前
|
存储 Linux 测试技术
在Linux中,如何实现文件系统的快照和克隆?
在Linux中,如何实现文件系统的快照和克隆?
|
5月前
|
存储 数据中心 数据安全/隐私保护
【Azure 存储服务】ADLS Gen 2 Backup/软删除/Version管理/快照等功能参考资料
【Azure 存储服务】ADLS Gen 2 Backup/软删除/Version管理/快照等功能参考资料
|
5月前
|
Linux
在Linux中,如何使用tar命令创建和恢复备份?
在Linux中,如何使用tar命令创建和恢复备份?
|
8月前
|
前端开发 Java Maven
项目快照 vs 版本
Maven快照(SNAPSHOT)解决多团队协作时频繁更新问题。当data-service团队频繁发布bug修复或改进到远程仓库时,app-ui团队需不断更新依赖版本。SNAPSHOT是开发进度的临时副本,每次构建都会检查远程仓库的新版本。app-ui通过依赖data-service:1.0-SNAPSHOT,能自动获取最新快照,无需手动升级版本号。在pom.xml中声明SNAPSHOT依赖,实现自动更新。
|
Linux Shell
CentOS7下重建grub并恢复系统的故障案例
CentOS7下重建grub并恢复系统的故障案例
753 0
CentOS7下重建grub并恢复系统的故障案例
|
Oracle 关系型数据库 Java
oracle学习81-打不开磁盘“D:\CentOS7\CentOS7.vmdk”或它所依赖的某个快照磁盘。
oracle学习81-打不开磁盘“D:\CentOS7\CentOS7.vmdk”或它所依赖的某个快照磁盘。
293 0
oracle学习81-打不开磁盘“D:\CentOS7\CentOS7.vmdk”或它所依赖的某个快照磁盘。
|
Java Maven 数据安全/隐私保护
pom配置之:<distributionManagement>snapshot快照库和release发布库
pom配置之:<distributionManagement>snapshot快照库和release发布库
880 0
pom配置之:<distributionManagement>snapshot快照库和release发布库
|
存储 SQL 弹性计算
Linux 实例中为MySQL创建应用一致性快照最佳实践
Linux 实例中的MySQL在快照生成的某一时刻,应用一致性快照确保虚拟机内部正在进行的文件系统的写入IO、系统缓存及数据库事务完成提交。在系统恢复时刻具有更快的启动速度及更低的恢复时间RTO。
365 0
Linux 实例中为MySQL创建应用一致性快照最佳实践
|
Unix Linux 数据处理
LINUX进阶(基础篇)之数据同步写入磁盘:sync
LINUX进阶(基础篇)之数据同步写入磁盘:sync
822 0
|
机器学习/深度学习 网络协议 Linux
Linux存储入门:简易数据恢复方案--分区和LVM实战
以黑箱方式完全依赖工具来进行数据恢复,所需时间和恢复的结果都难以估计。以专家或者专业方式进行数据恢复,技能和成本又太高。那么,数据恢复有没有较为合适的简易方案呢?我们以处理过的实际案例作答。
6602 0

热门文章

最新文章