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

  一、快照的工作原理

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

  二、快照的实现

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

[[email protected] ~]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  xxx  test -wi-a----- 12.00g
[[email protected] ~]# 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

[[email protected] ~]#

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

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

[[email protected] ~]# 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
[[email protected] ~]# ls
hellodb_innodb.sql  test
[[email protected] ~]#
[[email protected] ~]# 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
[[email protected] ~]# ls /mnt
fstab  inittab  lost+found
[[email protected] ~]# 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

[[email protected] ~]# lvcreate -L 1G -n lv_xxx_snap -p r -s /dev/test/xxx
  Logical volume "lv_xxx_snap" created.
[[email protected] ~]# 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
[[email protected] ~]#

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

[[email protected] ~]# 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

[[email protected] ~]#

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

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

[[email protected] ~]# mkdir /snap
[[email protected] ~]# mount /dev/test/lv_xxx_snap /snap
mount: /dev/mapper/test-lv_xxx_snap is write-protected, mounting read-only
[[email protected] ~]# ls /snap/
fstab  inittab  lost+found
[[email protected] ~]# 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
[[email protected] ~]#

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

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

[[email protected]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
[[email protected] ~]# 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
[[email protected] ~]# echo "this is test file " > /mnt/fstab
[[email protected] ~]# cat /mnt/fstab
this is test file
[[email protected] ~]# 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
[[email protected] ~]#

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

  三、快照还原

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

[[email protected] ~]# 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
[[email protected] ~]# umount /mnt
[[email protected] ~]# umount /snap/
[[email protected] ~]# 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
[[email protected] ~]#

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

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

[[email protected] ~]# 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
[[email protected] ~]# lvconvert --merge /dev/test/lv_xxx_snap
  Merging of volume test/lv_xxx_snap started.
  test/xxx: Merged: 100.00%
[[email protected] ~]# lvs
  LV   VG   Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  xxx  test -wi-a----- 12.00g
[[email protected] ~]#

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

  3)挂载LV 查看数据

[[email protected] ~]# mount /dev/test/xxx /mnt
[[email protected] ~]# ls /mnt
fstab  inittab  lost+found
[[email protected] ~]# 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
[[email protected] ~]#

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

原文地址:https://www.cnblogs.com/qiuhom-1874/p/12180505.html

时间: 2024-08-01 15:17:26

Linux磁盘管理之LVM逻辑卷快照的相关文章

Linux磁盘管理:LVM逻辑卷创建及使用

Linux磁盘管理:LVM逻辑卷创建及使用    一.创建LVM逻辑卷    通过图文并茂的方式来看看如何创建我们的LVM ,首先是要将我们的物理硬盘格式化成PV,然后将多个PV加入到创建好的VG中,最后通过VG创建我们的LV.所以我们第一步就是将我们的物理硬盘格式化成PV(物理卷) ①将物理硬盘格式化成PV(物理卷) 使用的是 pvcreate 命令 这里我已经事先虚拟化了3快物理硬盘,每块硬盘的大小为8G,通过 fdisk -l 命令可以查看 [[email protected] ~]# f

【转载】Linux磁盘管理:LVM逻辑卷管理

Linux学习之CentOS(二十五)--Linux磁盘管理:LVM逻辑卷基本概念及LVM的工作原理 这篇随笔将详细讲解Linux磁盘管理机制中的LVM逻辑卷的基本概念以及LVM的工作原理!!! 一.传统的磁盘管理 其实在Linux操作系统中,我们的磁盘管理机制和windows上的差不多,绝大多数都是使用MBR(Master Boot Recorder)都是通过先对一个硬盘进行分区,然后再将该分区进行文件系统的格式化,在Linux系统中如果要使用该分区就将其挂载上去即可,windows的话其实底

LInux磁盘管理:LVM逻辑卷

Linux磁盘管理:LVM逻辑卷 LVM简介   LVM(Logical Volume Manager 逻辑卷管理),是Linux操作系统的逻辑卷管理器.   LVM将一个或多个硬盘的分区在逻辑上集合,相当于一个大硬盘来使用,当硬盘的空间不够使用的时候,可以继续将其它的硬盘的分区加入其中,这样可以实现磁盘空间的动态管理,相对于普通的磁盘分区有很大的灵活性.   与传统的磁盘与分区相比,LVM为计算机提供了更高层次的磁盘存储.它使系统管理员可以更方便的为应用与用户分配存储空间. 逻辑卷基本术语 物

linux磁盘管理之LVM逻辑卷认识与管理详解(实验详细,可跟做)

Linux磁盘管理之LVM逻辑卷认识与管理详解 前言 本文接着上篇文章作如下延伸:链接:Linux磁盘管理之磁盘管理与文件系统 什么是LVM?为什么需要LVM? 如何具体进行LVM逻辑卷管理? 什么是磁盘配额?为什么需要磁盘配额? 在Linux中进行磁盘配额的条件是什么呢? 如何具体进行磁盘配额? 下面对以上问题逐一讲解,深入实例进行操作,带你深入理解linux磁盘管理之LVM逻辑卷管理. 一.LVM概述 1.什么是LVM?为什么需要LVM? ? 许多 Linux 使用者安装操作系统时都会遇到这

Linux磁盘管理:LVM逻辑卷的创建及使用

一.创建LVM逻辑卷 事先添加了三块虚拟物理磁盘/dev/sdb 1G, /dev/sdc 2G, /dev/sdd 3G 使用fdisk –l命令查看: [[email protected] ~]# fdisk -l Disk /dev/sda: 8589 MB, 8589934592 bytes, 16777216 sectorsUnits = sectors of 1 * 512 = 512 bytesSector size (logical/physical): 512 bytes /

Linux磁盘管理:LVM逻辑卷的拉伸及缩减

转载:http://www.cnblogs.com/xiaoluo501395377/archive/2013/05/24/3097785.html 在上一篇详细讲解了LVM逻辑卷的创建及使用,我们知道创建逻辑卷的步骤是先格式化物理硬盘位PV,然后创建一个VG,再将多个PV加入到VG中,最后基于VG创建我们的LV.在这篇随笔里,我们将继续学习LVM逻辑卷的知识,包括逻辑卷的拉伸及缩减... 一.拉伸一个逻辑卷 我们知道相比于传统磁盘管理方式的各种问题,使用LVM逻辑卷来管理我们的磁盘,我们可以对

Linux入门之磁盘管理(9)LVM逻辑卷案例

Linux入门之磁盘管理(9)LVM逻辑卷案例 案例介绍阶段(1): 创建一个由两个物理卷组成的大小未20G的卷组myvg,要求其PE大小为16M:而在此卷组中创建一个大小未5G的逻辑卷lvtest,此逻辑卷要能在开机后自动挂载至/mnt/lvtest目录,且支持ACL功能. 1.准备工作 #这里我们分别从两个磁盘选择10G来准备组合为PV [[email protected] ~]# fdisk -l | grep -o '/.*B' /dev/sda: 21.5 GB /dev/sdb: 2

Linux入门之磁盘管理(8)LVM逻辑卷的使用

在Linux中虽然有raid来保证数据的稳定以及磁盘性能的提高,但是其扩展性并不是很好,在很多生产环境中,都是数据正在使用中,在这时如果中断一段时间就会有很大的损失,因此Linux提供了LVM虚拟逻辑卷的概念,同样多个磁盘设备或分区设备组合在一起,但是,如果空间需要缩减或者扩展,可以很方便的进行动态改变,甚至进行数据快照. 逻辑卷管理器(LVM): 1.允许对卷进行方便操作的抽象层,包括重新定义文件系统的大小 2.允许在多个目录设备间重新组织文件系统 (1)将设备指定为物理卷 (2)用一个或多个

磁盘管理:LVM逻辑卷

LVM简介 ??LVM(Logical Volume Manager 逻辑卷管理),是Linux操作系统的逻辑卷管理器.??LVM将一个或多个硬盘的分区在逻辑上集合,相当于一个大硬盘来使用,当硬盘的空间不够使用的时候,可以继续将其它的硬盘的分区加入其中,这样可以实现磁盘空间的动态管理,相对于普通的磁盘分区有很大的灵活性.??与传统的磁盘与分区相比,LVM为计算机提供了更高层次的磁盘存储.它使系统管理员可以更方便的为应用与用户分配存储空间. 逻辑卷基本术语 物理存储介质(The physical