本文介绍分两部分,第一部分介绍如何恢复已删除的逻辑卷,如要执行恢复将使用vgcfgrestore命令。第二部分详细介绍如何从已删除的物理卷或故障磁盘场景中恢复。
在LVM中恢复已删除的逻辑卷
在执行任何逻辑卷管理相关任务时,如果意外的删除了逻辑卷,则可以使用它的数据还原功能来恢复逻辑卷。在下面的步骤中,将演示如何通过删除卷组中的任何一个逻辑卷,并恢复已删除的逻辑卷。
系统环境
Centos8
现有的文件系统
在开始本文之前已经创建了一个逻辑卷,里面并存放了一些文件。
- [root@localhost ~]# pvs
- PV VG Fmt Attr PSize PFree
- /dev/nvme0n1p2 cl lvm2 a-- <19.00g <2.00g
- /dev/sda vg_data lvm2 a-- <20.00g 0
- /dev/sdb vg_data lvm2 a-- <20.00g 0
- [root@localhost ~]# vgs
- VG #PV #LV #SN Attr VSize VFree
- cl 1 2 0 wz--n- <19.00g <2.00g
- vg_data 2 1 0 wz--n- 39.99g 0
- [root@localhost ~]# lvs
- LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert
- root cl -wi-ao---- 15.00g
- swap cl -wi-ao---- 2.00g
- lv_data vg_data -wi-ao---- 39.99g
- [root@localhost ~]# df -h /data
- Filesystem Size Used Avail Use% Mounted on
- /dev/mapper/vg_data-lv_data 40G 318M 40G 1% /data
/data目录中的文件如下:
意外删除逻辑卷
为了演示起见,请删除逻辑卷lv_data。
- [root@localhost ~]# umount /data
- [root@localhost ~]# lvremove -v /dev/vg_data/lv_data
- Do you really want to remove active logical volume vg_data/lv_data? [y/n]: y
- Accepted input: [y]
- Removing vg_data-lv_data (253:2)
- Archiving volume group "vg_data" metadata (seqno 2).
- Releasing logical volume "lv_data"
- Creating volume group backup "/etc/lvm/backup/vg_data" (seqno 3).
- Logical volume "lv_data" successfully removed
使用lvs命令打印并确认我们已经删除了逻辑卷lv_data:
由于lv_data卷已删除,可以看到卷组vg_data的剩余空间是40G。
- [root@localhost ~]# vgs
- VG #PV #LV #SN Attr VSize VFree
- cl 1 2 0 wz--n- <19.00g <2.00g
- vg_data 2 0 0 wz--n- 39.99g 39.99g
开始恢复逻辑卷
现在,让我们看看如何还原已删除的逻辑卷。每当我们执行与LVM相关的任何任务(时,所有内容都将被记录在/etc/lvm/archive.下。并使用vgcfgbackup命令备份卷组配置并将其存储在/etc/lvm/backup下。
- [root@localhost ~]# ll /etc/lvm/backup/
- total 8
- -rw-------. 1 root root 1746 Mar 9 16:27 cl
- -rw-------. 1 root root 1147 Apr 8 10:20 vg_data
- [root@localhost ~]# ll /etc/lvm/archive/
- total 24
- -rw-------. 1 root root 1740 Dec 29 2019 cl_00000-1531402016.vg
- -rw-------. 1 root root 1740 Mar 9 16:27 cl_00001-790744555.vg
- -rw-------. 1 root root 1747 Mar 9 16:27 cl_00002-1369752011.vg
- -rw-------. 1 root root 1150 Apr 8 09:52 vg_data_00000-919482485.vg
- -rw-------. 1 root root 1155 Apr 8 09:54 vg_data_00001-1289102393.vg
- -rw-------. 1 root root 1763 Apr 8 10:20 vg_data_00002-1932879749.vg
在上面删除逻辑卷的步骤中,使用lvremove -v /dev/vg_data/lv_data 命令时,可以看到输出的详细信息,有archiving和create backup。
下面列出并检查有多少个卷组元数据备份可用:
- [root@localhost ~]# vgcfgrestore --list vg_data
- File: /etc/lvm/archive/vg_data_00000-919482485.vg
- Couldn't find device with uuid l5rSrt-SRfc-KQNw-Tm29-gx4D-ihBw-Xzum3L.
- Couldn't find device with uuid v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD.
- VG name: vg_data
- Description: Created *before* executing 'vgcreate vg_data /dev/sda /dev/sdb'
- Backup Time: Thu Apr 8 09:52:49 2021
- File: /etc/lvm/archive/vg_data_00001-1289102393.vg
- VG name: vg_data
- Description: Created *before* executing 'lvcreate -l 100%FREE -n lv_data vg_data'
- Backup Time: Thu Apr 8 09:54:45 2021
- File: /etc/lvm/archive/vg_data_00002-1932879749.vg
- VG name: vg_data
- Description: Created *before* executing 'lvremove -v /dev/vg_data/lv_data'
- Backup Time: Thu Apr 8 10:20:53 2021
- File: /etc/lvm/backup/vg_data
- VG name: vg_data
- Description: Created *after* executing 'lvremove -v /dev/vg_data/lv_data'
- Backup Time: Thu Apr 8 10:20:53 2021
--list选项列出与VG有关的元数据备份和存档文件。
我们要恢复的事删除卷组之前的存档,所以选择下面圈出来的/etc/lvm/archive/vg_data_00002-1932879749.vg文件。
在恢复之前,使用--test选项来试运行一下:
- [root@localhost ~]# vgcfgrestore vg_data -f /etc/lvm/archive/vg_data_00002-1932879749.vg --test
- TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated.
- Restored volume group vg_data.
试运行没问题之后,去掉--test选项,然后再执行一次:
- [root@localhost ~]# vgcfgrestore vg_data -f /etc/lvm/archive/vg_data_00002-1932879749.vg
- Restored volume group vg_data.
可看到成功恢复卷组vg_data。
-f选项读取由vgcfgbackup创建的元数据文件。
使用lvs查看lv_data逻辑卷是否已恢复,并且使用lvscan查看逻辑卷是否激活:
- [root@localhost ~]# lvs
- LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert
- root cl -wi-ao---- 15.00g
- swap cl -wi-ao---- 2.00g
- lv_data vg_data -wi------- 39.99g
- [root@localhost ~]# lvscan
- ACTIVE '/dev/cl/swap' [2.00 GiB] inherit
- ACTIVE '/dev/cl/root' [15.00 GiB] inherit
- inactive '/dev/vg_data/lv_data' [39.99 GiB] inherit
可看到lv_data已恢复,但是状态是未激活。下一步就激活逻辑卷。
激活逻辑卷
使用lvchange命令将逻辑卷激活:
- [root@localhost ~]# lvchange -ay /dev/vg_data/lv_data
- [root@localhost ~]# lvscan
- ACTIVE '/dev/cl/swap' [2.00 GiB] inherit
- ACTIVE '/dev/cl/root' [15.00 GiB] inherit
- ACTIVE '/dev/vg_data/lv_data' [39.99 GiB] inherit
- [root@localhost ~]# lvs
- LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert
- root cl -wi-ao---- 15.00g
- swap cl -wi-ao---- 2.00g
- lv_data vg_data -wi-a----- 39.99g
上图可以看到"/dev/vg_data/lv_data"逻辑卷已激活。
挂载并检验
挂载文件系统:
- [root@localhost ~]# mount /dev/vg_data/lv_data /data/
- [root@localhost ~]# df -h /data
- Filesystem Size Used Avail Use% Mounted on
- /dev/mapper/vg_data-lv_data 40G 318M 40G 1% /data
可以看到文件都已经存在了。
以上部分已经成功地从卷组的元数据中恢复被删除的逻辑卷。
在LVM中恢复已删除的物理卷
系统环境
Centos8
现有的文件系统
下面使用了/dev/sd[a-c]三块磁盘,将他们划入一个卷组,创建两个逻辑卷:
- # Create pv
- [root@localhost ~]# pvcreate /dev/sda
- [root@localhost ~]# pvcreate /dev/sdb
- [root@localhost ~]# pvcreate /dev/sdc
- # Create VG
- [root@localhost ~]# vgcreate vg_data /dev/sd[a-c]
- # Create LV
- [root@localhost ~]# lvcreate -L 25G -n lv_data vg_data
- [root@localhost ~]# lvcreate -L 25G -n lv_log vg_data
下面列出逻辑卷的分配使用信息:
- [root@localhost ~]# pvs
- PV VG Fmt Attr PSize PFree
- /dev/nvme0n1p2 cl lvm2 a-- <19.00g <2.00g
- /dev/sda vg_data lvm2 a-- <20.00g 0
- /dev/sdb vg_data lvm2 a-- <20.00g <9.99g
- /dev/sdc vg_data lvm2 a-- <20.00g 0
- [root@localhost ~]# vgs
- VG #PV #LV #SN Attr VSize VFree
- cl 1 2 0 wz--n- <19.00g <2.00g
- vg_data 3 2 0 wz--n- <59.99g <9.99g
- [root@localhost ~]# lvs -a -o +devices
- LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert Devices
- root cl -wi-ao---- 15.00g /dev/nvme0n1p2(512)
- swap cl -wi-ao---- 2.00g /dev/nvme0n1p2(0)
- lv_data vg_data -wi-a----- 25.00g /dev/sda(0)
- lv_data vg_data -wi-a----- 25.00g /dev/sdb(0)
- lv_log vg_data -wi-a----- 25.00g /dev/sdc(0)
- lv_log vg_data -wi-a----- 25.00g
在根目录创建两个文件夹/data和/log,格式化逻辑卷,挂载逻辑卷,并存放一些数据:
- [root@localhost ~]# mkdir /data /logs
- [root@localhost ~]# mkfs.xfs /dev/vg_data/lv_data
- [root@localhost ~]# mkfs.xfs /dev/vg_data/lv_log
- [root@localhost ~]# mount /dev/vg_data/lv_data /data
- [root@localhost ~]# mount /dev/vg_data/lv_log /data
- [root@localhost ~]# df -h
- Filesystem Size Used Avail Use% Mounted on
- devtmpfs 880M 0 880M 0% /dev
- tmpfs 897M 0 897M 0% /dev/shm
- tmpfs 897M 8.7M 888M 1% /run
- tmpfs 897M 0 897M 0% /sys/fs/cgroup
- /dev/mapper/cl-root 15G 1.9G 14G 13% /
- /dev/nvme0n1p1 976M 183M 726M 21% /boot
- tmpfs 180M 0 180M 0% /run/user/0
- /dev/mapper/vg_data-lv_log 25G 211M 25G 1% /data
- [root@localhost ~]# touch /data/file{1..10}.txt
- [root@localhost ~]# touch /logs/text{1..10}.log
将磁盘设置为故障或删除磁盘
这两种情况是意外删除的物理卷或发生故障的磁盘,通过运行pvremove命令删除了任何一个物理卷,或者从虚拟机中移除某一块物理磁盘。
下面从虚拟机中移除一块物理磁盘:
重启系统之后,发现不能挂载lv_data和lv_log逻辑卷了,/dev目录中找不到vg_data卷组。
如果该逻辑卷设置为开机自动启动了,磁盘发生故障后,由于两个逻辑卷无法挂载文件系统,因此重新引导不能进入系统。只能通过进入单用户模式,并注释fstab配置文件里面和该逻辑卷相关的条目。
添加新物理硬盘
下面从虚拟机中添加一个新的物理磁盘,新添加的磁盘会变成/dev/sdc
- [root@localhost ~]# lsblk -S
- NAME HCTL TYPE VENDOR MODEL REV TRAN
- sda 6:0:0:0 disk VMware, VMware Virtual S 1.0 spi
- sdb 6:0:2:0 disk VMware, VMware Virtual S 1.0 spi
- sdc 6:0:3:0 disk VMware, VMware Virtual S 1.0 spi
- sr0 3:0:0:0 rom NECVMWar VMware SATA CD01 1.00 sata
恢复已删除物理卷的元数据
现在让我们开始为已删除的物理卷恢复元数据。当使用pvs,vgs,lvs命令时,它将警告缺少xxxxx UUID的设备之一。
只需复制UUID并使用grep查看存档和备份。在进行重新引导之前,报告的UUID指的是/dev/sdb设备。
- [root@localhost ~]# cat /etc/lvm/archive/vg_data_00002-1587647360.vg |grep -B 2 -A 9 "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD"
- pv1 {
- id = "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD"
- device = "/dev/sdb" # Hint only
- status = ["ALLOCATABLE"]
- flags = []
- dev_size = 41943040 # 20 Gigabytes
- pe_start = 2048
- pe_count = 5119 # 19.9961 Gigabytes
- }
- [root@localhost ~]# cat /etc/lvm/backup/vg_data |grep -B 2 -A 9 "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD"
- pv1 {
- id = "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD"
- device = "/dev/sdb" # Hint only
- status = ["ALLOCATABLE"]
- flags = []
- dev_size = 41943040 # 20 Gigabytes
- pe_start = 2048
- pe_count = 5119 # 19.9961 Gigabytes
- }
让我们先使用pvcreate --test进行试运行:
- [root@localhost ~]# pvcreate --test --uuid "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" --restorefile /etc/lvm/archive/vg_data_00002-1587647360.vg /dev/sdc
- TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated.
- Couldn't find device with uuid l5rSrt-SRfc-KQNw-Tm29-gx4D-ihBw-Xzum3L.
- Couldn't find device with uuid v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD.
- Couldn't find device with uuid UYyDyH-vc6D-XbQ7-ga1X-DKeM-ObLe-tdBLxR.
- Physical volume "/dev/sdc" successfully created.
--test 试运行
--uuid 用于指定新创建的物理卷的uuid值。如果没有此选项,将生成随机UUID。在本实验中指定的uuid值是之前删除物理卷的uuid值。
--restorefile 读取由vgcfgbackup生成的存档文件
去掉--test选项,正式创建物理卷:
- [root@localhost ~]# pvcreate --uuid "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" --restorefile /etc/lvm/archive/vg_data_00002-1587647360.vg /dev/sdc
- Couldn't find device with uuid l5rSrt-SRfc-KQNw-Tm29-gx4D-ihBw-Xzum3L.
- Couldn't find device with uuid v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD.
- Couldn't find device with uuid UYyDyH-vc6D-XbQ7-ga1X-DKeM-ObLe-tdBLxR.
- Physical volume "/dev/sdc" successfully created.
- [root@localhost ~]# pvs
- PV VG Fmt Attr PSize PFree
- /dev/nvme0n1p2 cl lvm2 a-- <19.00g <2.00g
- /dev/sda vg_data lvm2 a-- <20.00g 0
- /dev/sdb vg_data lvm2 a-- <20.00g 0
- /dev/sdc vg_data lvm2 a-- <20.00g <9.99g
- [root@localhost ~]# vgs
- VG #PV #LV #SN Attr VSize VFree
- cl 1 2 0 wz--n- <19.00g <2.00g
- vg_data 3 2 0 wz--n- <59.99g <9.99g
- [root@localhost ~]# lvs -o +devices
- LV VG Attr LSize Pool Origin Data% Meta% Move Log Cpy%Sync Convert Devices
- root cl -wi-ao---- 15.00g /dev/nvme0n1p2(512)
- swap cl -wi-ao---- 2.00g /dev/nvme0n1p2(0)
- lv_data vg_data -wi-a----- 25.00g /dev/sda(0)
- lv_data vg_data -wi-a----- 25.00g /dev/sdc(0)
- lv_log vg_data -wi-a----- 25.00g /dev/sdb(0)
- lv_log vg_data -wi-a----- 25.00g
恢复卷组
然后使用lvm的备份还原卷组。首先加入--test试运行一下:
- [root@localhost ~]# vgcfgrestore --test -f /etc/lvm/backup/vg_data vg_data
- TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated.
- Volume group vg_data has active volume: lv_log.
- Volume group vg_data has active volume: lv_data.
- WARNING: Found 2 active volume(s) in volume group "vg_data".
- Restoring VG with active LVs, may cause mismatch with its metadata.
- Do you really want to proceed with restore of volume group "vg_data", while 2 volume(s) are active? [y/n]: y
- Restored volume group vg_data.
下面正式运行一下,去掉--test选项:
- [root@localhost ~]# vgcfgrestore -f /etc/lvm/backup/vg_data vg_data
- Volume group vg_data has active volume: lv_log.
- Volume group vg_data has active volume: lv_data.
- WARNING: Found 2 active volume(s) in volume group "vg_data".
- Restoring VG with active LVs, may cause mismatch with its metadata.
- Do you really want to proceed with restore of volume group "vg_data", while 2 volume(s) are active? [y/n]: y
- Restored volume group vg_data.
如果卷组和逻辑卷未激活,请使用下面命令激活:
- # 扫描卷组
- [root@localhost ~]# vgscan
- Reading all physical volumes. This may take a while...
- Found volume group "cl" using metadata type lvm2
- Found volume group "vg_data" using metadata type lvm2
- # 激活卷组vg_data
- [root@localhost ~]# vgchange -ay vg_data
- 2 logical volume(s) in volume group "vg_data" now active
- # 扫描逻辑卷
- [root@localhost ~]# lvscan
- ACTIVE '/dev/cl/swap' [2.00 GiB] inherit
- ACTIVE '/dev/cl/root' [15.00 GiB] inherit
- ACTIVE '/dev/vg_data/lv_data' [25.00 GiB] inherit
- ACTIVE '/dev/vg_data/lv_log' [25.00 GiB] inherit
在lvm中,需要执行一些步骤来恢复已删除的物理卷,方法是添加新磁盘并用现有UUID指向新磁盘。
本文转载自微信公众号「Linux就该这么学」,可以通过以下二维码关注。转载本文请联系Linux就该这么学公众号。