Linux磁盘管理之LVM逻辑卷快照

  一、快照的工作原理

  所谓快照就是将当时的系统数据记录下来,在未来若有数据变动,则会将变更前的数据放入快照区进行保存。我们可理解为快照就是给系统拍了一张照片,记录当时系统在拍快照的状态。只不过现实生活中的照片是没有办法将现在的生活还原到照片的时候,而Linux系统里LVM快照是可以的。从上面的阐述可以了解到,被做快照的逻辑卷是分成了两个部分,一部分是数据没有改动前的和数据变更后的。它是怎么工作的呢?在我们给系统做快照的前提是,系统上基于LVM管理的,且快照和逻辑卷必须是在同一卷组上;在我们给LVM管理的系统上做快照卷的时候,快照不可以给多个逻辑卷一起做,它是一个逻辑卷对应一个快照卷,不可以多个逻辑卷对应一个快照卷。快照是一次性使用,还原了快照,随之快照就失效,消失。接下来说说原理吧。快照是特殊的逻辑卷,它之所以要和被做快照的逻辑卷一个卷组是因为它在生成快照时,它是和LV共享很多PE的区块,因此快照必须同LV同一个卷组中。之所以叫快照,就是因为它快嘛,它为什么快,这就要和它的工作原理有密切的关系了,快照生成时,实际上它不是去拷贝原LV里的数据,它只是分配我们指定大小的空间,在原LV上的数据发生变化时,这个时候快照会把发生改变的数据先拷贝到快照区,这样一来快照就只是存放着被修改之前的数据。这样就起到了备份修改数据的作用,修改后的数据就存放在原LV上。如果有一天我们需要还原快照,这个时候快照就会和先有的LV做合并,快照里面存放修改之前的数据,快照和现有LV做合并时,快照上的数据会覆盖现有LV上数据,这样一来就实现了把数据还原到拍快照当时的状态。这里需要注意一点的是快照只是覆盖改变后的数据,没有做改变的数据它是不会去覆盖的。所以快照使用过后它就没有任何意义,它不可以再次记录恢复后数据的变化前的数据。在做快照的时候我们还需要注意其快照的大小,快照指定的空间大小不要太小,太小可能装不小变化前的数据,导致快照失效,当然空间也不宜太大,太大浪费空间没有意义,空间超过原LV大小,其实也是没有意义的,它最大空间就是和原LV大小相等,所以在做快照时,我们需要评估大概有多少的数据在发生变化,避免空间过小导致快照失效。

  二、快照的实现

  1)查看现有逻辑卷所在卷组空间是否足够创建快照

[root@test-centos7-node1 ~]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  xxx  test -wi-a----- 12.00g                                                    
[root@test-centos7-node1 ~]# vgdisplay test
  --- Volume group ---
  VG Name               test
  System ID             
  Format                lvm2
  Metadata Areas        3
  Metadata Sequence No  51
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                1
  Open LV               0
  Max PV                0
  Cur PV                3
  Act PV                3
  VG Size               <29.98 GiB
  PE Size               8.00 MiB
  Total PE              3837
  Alloc PE / Size       1536 / 12.00 GiB
  Free  PE / Size       2301 / <17.98 GiB
  VG UUID               31vxAP-L5jb-8Yxm-25m2-LdD0-ee8R-sdTjum
   
[root@test-centos7-node1 ~]# 

  说明:这是已经创建好逻辑卷的系统上查看的,有关逻辑卷的管理请参考https://www.cnblogs.com/qiuhom-1874/p/12156146.html,可以看到还有17个G处于空闲状态

  2)针对现有逻辑卷创建快照

[root@test-centos7-node1 ~]# df
Filesystem           1K-blocks    Used Available Use% Mounted on
/dev/sda3             48209924 1618304  46591620   4% /
devtmpfs               1922828       0   1922828   0% /dev
tmpfs                  1932652       0   1932652   0% /dev/shm
tmpfs                  1932652    8792   1923860   1% /run
tmpfs                  1932652       0   1932652   0% /sys/fs/cgroup
/dev/sda1              2086912  137672   1949240   7% /boot
tmpfs                   386532       0    386532   0% /run/user/0
/dev/mapper/test-xxx  10190100   36896   9612536   1% /mnt
[root@test-centos7-node1 ~]# ls
hellodb_innodb.sql  test
[root@test-centos7-node1 ~]# 
[root@test-centos7-node1 ~]# df 
Filesystem           1K-blocks    Used Available Use% Mounted on
/dev/sda3             48209924 1618304  46591620   4% /
devtmpfs               1922828       0   1922828   0% /dev
tmpfs                  1932652       0   1932652   0% /dev/shm
tmpfs                  1932652    8792   1923860   1% /run
tmpfs                  1932652       0   1932652   0% /sys/fs/cgroup
/dev/sda1              2086912  137672   1949240   7% /boot
tmpfs                   386532       0    386532   0% /run/user/0
/dev/mapper/test-xxx  10190100   36896   9612536   1% /mnt
[root@test-centos7-node1 ~]# ls /mnt
fstab  inittab  lost+found
[root@test-centos7-node1 ~]# vgdisplay 
  --- Volume group ---
  VG Name               test
  System ID             
  Format                lvm2
  Metadata Areas        3
  Metadata Sequence No  51
  VG Access             read/write
  VG Status             resizable
  MAX LV                0
  Cur LV                1
  Open LV               1
  Max PV                0
  Cur PV                3
  Act PV                3
  VG Size               <29.98 GiB
  PE Size               8.00 MiB
  Total PE              3837
  Alloc PE / Size       1536 / 12.00 GiB
  Free  PE / Size       2301 / <17.98 GiB
  VG UUID               31vxAP-L5jb-8Yxm-25m2-LdD0-ee8R-sdTjum
   
[root@test-centos7-node1 ~]# lvcreate -L 1G -n lv_xxx_snap -p r -s /dev/test/xxx 
  Logical volume "lv_xxx_snap" created.
[root@test-centos7-node1 ~]# lvs
  LV          VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  lv_xxx_snap test sri-a-s---  1.00g      xxx    0.01                                   
  xxx         test owi-aos--- 12.00g                                                    
[root@test-centos7-node1 ~]# 

  说明:创建快照和创建其他逻辑卷的命令是一样的,都是用lvcreate  其中-s就是指定创建的逻辑卷为快照 -p 指定其快照属性 r 表示只读属性 最后要跟上对那个逻辑卷做快照,当然我们指定被做快照的逻辑对应设备的路径,系统就能够分辨出快照该创建到那个VG上,所以我们这里是可不指定VG的名称的

[root@test-centos7-node1 ~]# lvdisplay /dev/test/lv_xxx_snap 
  --- Logical volume ---
  LV Path                /dev/test/lv_xxx_snap
  LV Name                lv_xxx_snap
  VG Name                test
  LV UUID                ZjBpYF-2fg6-n6Wz-ehJd-Zagv-lg3y-HFmHjz
  LV Write Access        read only
  LV Creation host, time test-centos7-node1, 2020-01-11 03:18:29 -0500
  LV snapshot status     active destination for xxx
  LV Status              available
  # open                 0
  LV Size                12.00 GiB
  Current LE             1536
  COW-table size         1.00 GiB
  COW-table LE           128
  Allocated to snapshot  0.01%
  Snapshot chunk size    4.00 KiB
  Segments               1
  Allocation             inherit
  Read ahead sectors     auto
  - currently set to     8192
  Block device           253:3
   
[root@test-centos7-node1 ~]# 

  说明:我们创建好快照,可用lvdisplay 指定快照对应设备路径来查看快照的详情,这个同查看逻辑卷的详情用法一致。可以看到该快照是用于xxx 逻辑卷的快照

  3)创建挂载目录挂载快照

[root@test-centos7-node1 ~]# mkdir /snap
[root@test-centos7-node1 ~]# mount /dev/test/lv_xxx_snap /snap
mount: /dev/mapper/test-lv_xxx_snap is write-protected, mounting read-only
[root@test-centos7-node1 ~]# ls /snap/
fstab  inittab  lost+found
[root@test-centos7-node1 ~]# df -h
Filesystem                    Size  Used Avail Use% Mounted on
/dev/sda3                      46G  1.6G   45G   4% /
devtmpfs                      1.9G     0  1.9G   0% /dev
tmpfs                         1.9G     0  1.9G   0% /dev/shm
tmpfs                         1.9G  8.7M  1.9G   1% /run
tmpfs                         1.9G     0  1.9G   0% /sys/fs/cgroup
/dev/sda1                     2.0G  135M  1.9G   7% /boot
tmpfs                         378M     0  378M   0% /run/user/0
/dev/mapper/test-xxx          9.8G   37M  9.2G   1% /mnt
/dev/mapper/test-lv_xxx_snap  9.8G   37M  9.2G   1% /snap
[root@test-centos7-node1 ~]# 

  说明:挂载上快照,我们发现快照的大小和被做快照的大小是一致的,使用量什么的都是一致的,上面不是说快照里面存放的是被修改前的数据吗,怎么有数据了呢,这是因为我们看到快照里面的数据不是快照本身的数据,是共享其原LV里的数据,所以我们是可以看到的,之所以能看到是系统把原有的LV数据镜像到快照里,让我们感觉里面是有东西的,就是告诉我们快照做好了,别担心。这里需要注意一点,如果原LV的文件系统上xfs文件系统,挂载的时候可能出现挂载不上的情况,原因是快照的UUID和原LV的UUID相同,xfs的文件系统默认挂载选项会检查UUID,如果冲突它会不让你挂载的,这个时候我们挂载需要指定其选项不检查UUID ,用 mount -o 来指定其挂载选项 nouuid 表示挂载不检查uuid;本人是把LV的文件系统格式化成ext4,所以挂载的时候没有加选项是可以挂载上去的;如果创建快照时没有指定为只读属性,那么挂载的时候建议大家加上挂载选项为只读,这样挂载上的快照才能不被修改的可能。

  4)修改原LV里的文件,看看快照卷里的文件是否有更改

[root@test-centos7-node1 ~]# cat /mnt/fstab 

#
# /etc/fstab
# Created by anaconda on Wed Jan  1 07:19:49 2020
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=fea42698-b2ff-41fb-b517-a1caa0b962d7 /                       xfs     defaults        0 0
UUID=512dff54-789c-41e8-8765-9542215f2a01 /boot                   xfs     defaults        0 0
UUID=e2582696-1cab-4c28-9793-108602f39f24 swap                    swap    defaults        0 0
[root@test-centos7-node1 ~]# cat /snap/fstab 

#
# /etc/fstab
# Created by anaconda on Wed Jan  1 07:19:49 2020
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=fea42698-b2ff-41fb-b517-a1caa0b962d7 /                       xfs     defaults        0 0
UUID=512dff54-789c-41e8-8765-9542215f2a01 /boot                   xfs     defaults        0 0
UUID=e2582696-1cab-4c28-9793-108602f39f24 swap                    swap    defaults        0 0
[root@test-centos7-node1 ~]# echo "this is test file " > /mnt/fstab 
[root@test-centos7-node1 ~]# cat /mnt/fstab
this is test file 
[root@test-centos7-node1 ~]# cat /snap/fstab

#
# /etc/fstab
# Created by anaconda on Wed Jan  1 07:19:49 2020
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=fea42698-b2ff-41fb-b517-a1caa0b962d7 /                       xfs     defaults        0 0
UUID=512dff54-789c-41e8-8765-9542215f2a01 /boot                   xfs     defaults        0 0
UUID=e2582696-1cab-4c28-9793-108602f39f24 swap                    swap    defaults        0 0
[root@test-centos7-node1 ~]# 

  说明:发现没有我们修改原LV里的数据后,快照里边的对应的文件内容没有发生变化,所以快照里边永远保存的是做快照那一刻的数据状态情况,中间怎么修改它都只保存最老的版本,LV里面保存最新版本的状态,这里需要提醒的是快照虽然有备份的效果,但是它不能代替备份,如果vg怀了,那么逻辑卷和快照都将失效。

  三、快照还原

  1) 取消逻辑卷和快照的挂载

[root@test-centos7-node1 ~]# df
Filesystem                   1K-blocks    Used Available Use% Mounted on
/dev/sda3                     48209924 1618368  46591556   4% /
devtmpfs                       1922828       0   1922828   0% /dev
tmpfs                          1932652       0   1932652   0% /dev/shm
tmpfs                          1932652    8776   1923876   1% /run
tmpfs                          1932652       0   1932652   0% /sys/fs/cgroup
/dev/sda1                      2086912  137672   1949240   7% /boot
tmpfs                           386532       0    386532   0% /run/user/0
/dev/mapper/test-xxx          10190100   36896   9612536   1% /mnt
/dev/mapper/test-lv_xxx_snap  10190100   36896   9612536   1% /snap
[root@test-centos7-node1 ~]# umount /mnt
[root@test-centos7-node1 ~]# umount /snap/
[root@test-centos7-node1 ~]# df
Filesystem     1K-blocks    Used Available Use% Mounted on
/dev/sda3       48209924 1618368  46591556   4% /
devtmpfs         1922828       0   1922828   0% /dev
tmpfs            1932652       0   1932652   0% /dev/shm
tmpfs            1932652    8776   1923876   1% /run
tmpfs            1932652       0   1932652   0% /sys/fs/cgroup
/dev/sda1        2086912  137672   1949240   7% /boot
tmpfs             386532       0    386532   0% /run/user/0
[root@test-centos7-node1 ~]# 

  说明:还原就是把快照和原LV合并,所以两者都必须是处于非挂载的状态

  2)合并逻辑卷和快照,进行数据还原

[root@test-centos7-node1 ~]# lvs
  LV          VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  lv_xxx_snap test sri-a-s---  1.00g      xxx    0.01                                   
  xxx         test owi-a-s--- 12.00g                                                    
[root@test-centos7-node1 ~]# lvconvert --merge /dev/test/lv_xxx_snap 
  Merging of volume test/lv_xxx_snap started.
  test/xxx: Merged: 100.00%
[root@test-centos7-node1 ~]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  xxx  test -wi-a----- 12.00g                                                    
[root@test-centos7-node1 ~]# 

  说明:合并快照和逻辑卷后,快照的的使命就完成了,当然快照也就没有存在的意义,系统会把快照给删除掉,在centos6上做合并是可看到删除快照成功的提示。我们指定合并的快照就可以了,因为快照里记录了原LV是哪一个,所以合并时不用在指定其原LV

  3)挂载LV 查看数据

[root@test-centos7-node1 ~]# mount /dev/test/xxx /mnt
[root@test-centos7-node1 ~]# ls /mnt
fstab  inittab  lost+found
[root@test-centos7-node1 ~]# cat /mnt/fstab 

#
# /etc/fstab
# Created by anaconda on Wed Jan  1 07:19:49 2020
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
UUID=fea42698-b2ff-41fb-b517-a1caa0b962d7 /                       xfs     defaults        0 0
UUID=512dff54-789c-41e8-8765-9542215f2a01 /boot                   xfs     defaults        0 0
UUID=e2582696-1cab-4c28-9793-108602f39f24 swap                    swap    defaults        0 0
[root@test-centos7-node1 ~]# 

  说明:可以看到fstab文件已经还原到被修改前的状态。这种方式是利用快照,还原到原有LV里,如果需要还原到其他LV里 这个时候就需先要把快照里的东西给备份出来,然后再复制给到其他LV里即可,当然这种方式就不是利用快照来还原,它的本质就是文件复制到另外的地方,和快照没有关系。快照只是记录快照生成时的数据状态,生产中建议利用快照来记录快照生成当时的数据状态,然后在把快照挂载到系统上,然后慢慢拷贝数据进行备份,拷贝完后删除快照。一般情况快照不易在系统上生存太长时间,时间越长,影响磁盘的I/O写入,可能影响服务器的性能。建议把快照里的数据拷完就删除快照。

posted @ 2020-01-12 19:08  Linux-1874  阅读(2832)  评论(0编辑  收藏  举报