教你在 LVM 中恢复已删除的逻辑卷和物理卷

系统 Linux
本文介绍分两部分,第一部分介绍如何恢复已删除的逻辑卷,如要执行恢复将使用vgcfgrestore命令。第二部分详细介绍如何从已删除的物理卷或故障磁盘场景中恢复。

[[403599]]

本文介绍分两部分,第一部分介绍如何恢复已删除的逻辑卷,如要执行恢复将使用vgcfgrestore命令。第二部分详细介绍如何从已删除的物理卷或故障磁盘场景中恢复。

在LVM中恢复已删除的逻辑卷

在执行任何逻辑卷管理相关任务时,如果意外的删除了逻辑卷,则可以使用它的数据还原功能来恢复逻辑卷。在下面的步骤中,将演示如何通过删除卷组中的任何一个逻辑卷,并恢复已删除的逻辑卷。

系统环境

Centos8

现有的文件系统

在开始本文之前已经创建了一个逻辑卷,里面并存放了一些文件。

  1. [root@localhost ~]# pvs 
  2.   PV             VG      Fmt  Attr PSize   PFree  
  3.   /dev/nvme0n1p2 cl      lvm2 a--  <19.00g <2.00g 
  4.   /dev/sda       vg_data lvm2 a--  <20.00g     0  
  5.   /dev/sdb       vg_data lvm2 a--  <20.00g     0  
  6. [root@localhost ~]# vgs 
  7.   VG      #PV #LV #SN Attr   VSize   VFree  
  8.   cl        1   2   0 wz--n- <19.00g <2.00g 
  9.   vg_data   2   1   0 wz--n-  39.99g     0  
  10. [root@localhost ~]# lvs 
  11.   LV      VG      Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert 
  12.   root    cl      -wi-ao---- 15.00g                                                     
  13.   swap    cl      -wi-ao----  2.00g                                                     
  14.   lv_data vg_data -wi-ao---- 39.99g                
  15. [root@localhost ~]# df -h /data 
  16. Filesystem                   Size  Used Avail Use% Mounted on 
  17. /dev/mapper/vg_data-lv_data   40G  318M   40G   1% /data 

/data目录中的文件如下:

意外删除逻辑卷

为了演示起见,请删除逻辑卷lv_data。

  1. [root@localhost ~]# umount /data  
  2. [root@localhost ~]# lvremove -v /dev/vg_data/lv_data  
  3. Do you really want to remove active logical volume vg_data/lv_data? [y/n]: y 
  4.     Accepted input: [y] 
  5.     Removing vg_data-lv_data (253:2) 
  6.     Archiving volume group "vg_data" metadata (seqno 2). 
  7.     Releasing logical volume "lv_data" 
  8.     Creating volume group backup "/etc/lvm/backup/vg_data" (seqno 3). 
  9.   Logical volume "lv_data" successfully removed 

使用lvs命令打印并确认我们已经删除了逻辑卷lv_data:

由于lv_data卷已删除,可以看到卷组vg_data的剩余空间是40G。

  1. [root@localhost ~]# vgs 
  2.   VG      #PV #LV #SN Attr   VSize   VFree  
  3.   cl        1   2   0 wz--n- <19.00g <2.00g 
  4.   vg_data   2   0   0 wz--n-  39.99g 39.99g 

开始恢复逻辑卷

现在,让我们看看如何还原已删除的逻辑卷。每当我们执行与LVM相关的任何任务(时,所有内容都将被记录在/etc/lvm/archive.下。并使用vgcfgbackup命令备份卷组配置并将其存储在/etc/lvm/backup下。

  1. [root@localhost ~]# ll /etc/lvm/backup/ 
  2. total 8 
  3. -rw-------. 1 root root 1746 Mar  9 16:27 cl 
  4. -rw-------. 1 root root 1147 Apr  8 10:20 vg_data 
  5. [root@localhost ~]# ll /etc/lvm/archive/ 
  6. total 24 
  7. -rw-------. 1 root root 1740 Dec 29  2019 cl_00000-1531402016.vg 
  8. -rw-------. 1 root root 1740 Mar  9 16:27 cl_00001-790744555.vg 
  9. -rw-------. 1 root root 1747 Mar  9 16:27 cl_00002-1369752011.vg 
  10. -rw-------. 1 root root 1150 Apr  8 09:52 vg_data_00000-919482485.vg 
  11. -rw-------. 1 root root 1155 Apr  8 09:54 vg_data_00001-1289102393.vg 
  12. -rw-------. 1 root root 1763 Apr  8 10:20 vg_data_00002-1932879749.vg 

在上面删除逻辑卷的步骤中,使用lvremove -v /dev/vg_data/lv_data 命令时,可以看到输出的详细信息,有archiving和create backup。

下面列出并检查有多少个卷组元数据备份可用:

  1. [root@localhost ~]# vgcfgrestore --list vg_data 
  2.  
  3.   File:        /etc/lvm/archive/vg_data_00000-919482485.vg 
  4.   Couldn't find device with uuid l5rSrt-SRfc-KQNw-Tm29-gx4D-ihBw-Xzum3L. 
  5.   Couldn't find device with uuid v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD. 
  6.   VG name:        vg_data 
  7.   Description:    Created *before* executing 'vgcreate vg_data /dev/sda /dev/sdb' 
  8.   Backup Time:    Thu Apr  8 09:52:49 2021 
  9.  
  10.   File:        /etc/lvm/archive/vg_data_00001-1289102393.vg 
  11.   VG name:        vg_data 
  12.   Description:    Created *before* executing 'lvcreate -l 100%FREE -n lv_data vg_data' 
  13.   Backup Time:    Thu Apr  8 09:54:45 2021 
  14.  
  15.   File:        /etc/lvm/archive/vg_data_00002-1932879749.vg 
  16.   VG name:        vg_data 
  17.   Description:    Created *before* executing 'lvremove -v /dev/vg_data/lv_data' 
  18.   Backup Time:    Thu Apr  8 10:20:53 2021 
  19.  
  20.   File:        /etc/lvm/backup/vg_data 
  21.   VG name:        vg_data 
  22.   Description:    Created *after* executing 'lvremove -v /dev/vg_data/lv_data' 
  23.   Backup Time:    Thu Apr  8 10:20:53 2021 

--list选项列出与VG有关的元数据备份和存档文件。

我们要恢复的事删除卷组之前的存档,所以选择下面圈出来的/etc/lvm/archive/vg_data_00002-1932879749.vg文件。

在恢复之前,使用--test选项来试运行一下:

  1. [root@localhost ~]# vgcfgrestore vg_data -f /etc/lvm/archive/vg_data_00002-1932879749.vg --test 
  2.   TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated. 
  3.   Restored volume group vg_data. 

试运行没问题之后,去掉--test选项,然后再执行一次:

  1. [root@localhost ~]# vgcfgrestore vg_data -f /etc/lvm/archive/vg_data_00002-1932879749.vg 
  2.   Restored volume group vg_data. 

可看到成功恢复卷组vg_data。

-f选项读取由vgcfgbackup创建的元数据文件。

使用lvs查看lv_data逻辑卷是否已恢复,并且使用lvscan查看逻辑卷是否激活:

  1. [root@localhost ~]# lvs 
  2.   LV      VG      Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert 
  3.   root    cl      -wi-ao---- 15.00g                                                     
  4.   swap    cl      -wi-ao----  2.00g                                                     
  5.   lv_data vg_data -wi------- 39.99g                                                     
  6. [root@localhost ~]# lvscan  
  7.   ACTIVE            '/dev/cl/swap' [2.00 GiB] inherit 
  8.   ACTIVE            '/dev/cl/root' [15.00 GiB] inherit 
  9.   inactive          '/dev/vg_data/lv_data' [39.99 GiB] inherit 

可看到lv_data已恢复,但是状态是未激活。下一步就激活逻辑卷。

激活逻辑卷

使用lvchange命令将逻辑卷激活:

  1. [root@localhost ~]# lvchange -ay /dev/vg_data/lv_data 
  2. [root@localhost ~]# lvscan  
  3.   ACTIVE            '/dev/cl/swap' [2.00 GiB] inherit 
  4.   ACTIVE            '/dev/cl/root' [15.00 GiB] inherit 
  5.   ACTIVE            '/dev/vg_data/lv_data' [39.99 GiB] inherit 
  6. [root@localhost ~]# lvs 
  7.   LV      VG      Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert 
  8.   root    cl      -wi-ao---- 15.00g                                                     
  9.   swap    cl      -wi-ao----  2.00g                                                     
  10.   lv_data vg_data -wi-a----- 39.99g 

上图可以看到"/dev/vg_data/lv_data"逻辑卷已激活。

挂载并检验

挂载文件系统:

  1. [root@localhost ~]# mount /dev/vg_data/lv_data /data/ 
  2. [root@localhost ~]# df -h /data 
  3. Filesystem                   Size  Used Avail Use% Mounted on 
  4. /dev/mapper/vg_data-lv_data   40G  318M   40G   1% /data 

可以看到文件都已经存在了。

以上部分已经成功地从卷组的元数据中恢复被删除的逻辑卷。

在LVM中恢复已删除的物理卷

系统环境

Centos8

现有的文件系统

下面使用了/dev/sd[a-c]三块磁盘,将他们划入一个卷组,创建两个逻辑卷:

  1. Create pv 
  2. [root@localhost ~]# pvcreate /dev/sda 
  3. [root@localhost ~]# pvcreate /dev/sdb 
  4. [root@localhost ~]# pvcreate /dev/sdc 
  5. Create VG 
  6. [root@localhost ~]# vgcreate vg_data /dev/sd[a-c] 
  7. Create LV 
  8. [root@localhost ~]# lvcreate -L 25G -n lv_data vg_data 
  9. [root@localhost ~]# lvcreate -L 25G -n lv_log vg_data 

下面列出逻辑卷的分配使用信息:

  1. [root@localhost ~]# pvs 
  2.   PV             VG      Fmt  Attr PSize   PFree  
  3.   /dev/nvme0n1p2 cl      lvm2 a--  <19.00g <2.00g 
  4.   /dev/sda       vg_data lvm2 a--  <20.00g     0  
  5.   /dev/sdb       vg_data lvm2 a--  <20.00g <9.99g 
  6.   /dev/sdc       vg_data lvm2 a--  <20.00g     0  
  7. [root@localhost ~]# vgs 
  8.   VG      #PV #LV #SN Attr   VSize   VFree  
  9.   cl        1   2   0 wz--n- <19.00g <2.00g 
  10.   vg_data   3   2   0 wz--n- <59.99g <9.99g 
  11. [root@localhost ~]# lvs -a -o +devices 
  12.   LV      VG      Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert Devices             
  13.   root    cl      -wi-ao---- 15.00g                                                     /dev/nvme0n1p2(512) 
  14.   swap    cl      -wi-ao----  2.00g                                                     /dev/nvme0n1p2(0)   
  15.   lv_data vg_data -wi-a----- 25.00g                                                     /dev/sda(0)         
  16.   lv_data vg_data -wi-a----- 25.00g                                                     /dev/sdb(0)         
  17.   lv_log  vg_data -wi-a----- 25.00g                                                     /dev/sdc(0)         
  18.   lv_log  vg_data -wi-a----- 25.00g          

在根目录创建两个文件夹/data和/log,格式化逻辑卷,挂载逻辑卷,并存放一些数据:

  1. [root@localhost ~]# mkdir /data /logs 
  2. [root@localhost ~]# mkfs.xfs /dev/vg_data/lv_data  
  3. [root@localhost ~]# mkfs.xfs /dev/vg_data/lv_log  
  4. [root@localhost ~]# mount /dev/vg_data/lv_data /data 
  5. [root@localhost ~]# mount /dev/vg_data/lv_log /data 
  6. [root@localhost ~]# df -h 
  7. Filesystem                  Size  Used Avail Use% Mounted on 
  8. devtmpfs                    880M     0  880M   0% /dev 
  9. tmpfs                       897M     0  897M   0% /dev/shm 
  10. tmpfs                       897M  8.7M  888M   1% /run 
  11. tmpfs                       897M     0  897M   0% /sys/fs/cgroup 
  12. /dev/mapper/cl-root          15G  1.9G   14G  13% / 
  13. /dev/nvme0n1p1              976M  183M  726M  21% /boot 
  14. tmpfs                       180M     0  180M   0% /run/user/0 
  15. /dev/mapper/vg_data-lv_log   25G  211M   25G   1% /data 
  16. [root@localhost ~]# touch /data/file{1..10}.txt 
  17. [root@localhost ~]# touch /logs/text{1..10}.log 

将磁盘设置为故障或删除磁盘

这两种情况是意外删除的物理卷或发生故障的磁盘,通过运行pvremove命令删除了任何一个物理卷,或者从虚拟机中移除某一块物理磁盘。

下面从虚拟机中移除一块物理磁盘:

重启系统之后,发现不能挂载lv_data和lv_log逻辑卷了,/dev目录中找不到vg_data卷组。

如果该逻辑卷设置为开机自动启动了,磁盘发生故障后,由于两个逻辑卷无法挂载文件系统,因此重新引导不能进入系统。只能通过进入单用户模式,并注释fstab配置文件里面和该逻辑卷相关的条目。

添加新物理硬盘

下面从虚拟机中添加一个新的物理磁盘,新添加的磁盘会变成/dev/sdc

  1. [root@localhost ~]# lsblk -S 
  2. NAME HCTL       TYPE VENDOR   MODEL             REV TRAN 
  3. sda  6:0:0:0    disk VMware,  VMware Virtual S 1.0  spi 
  4. sdb  6:0:2:0    disk VMware,  VMware Virtual S 1.0  spi 
  5. sdc  6:0:3:0    disk VMware,  VMware Virtual S 1.0  spi 
  6. sr0  3:0:0:0    rom  NECVMWar VMware SATA CD01 1.00 sata 

恢复已删除物理卷的元数据

现在让我们开始为已删除的物理卷恢复元数据。当使用pvs,vgs,lvs命令时,它将警告缺少xxxxx UUID的设备之一。

只需复制UUID并使用grep查看存档和备份。在进行重新引导之前,报告的UUID指的是/dev/sdb设备。

  1. [root@localhost ~]# cat /etc/lvm/archive/vg_data_00002-1587647360.vg |grep -B 2 -A 9 "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" 
  2.  
  3. pv1 { 
  4. id = "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" 
  5. device = "/dev/sdb" # Hint only 
  6.  
  7. status = ["ALLOCATABLE"
  8. flags = [] 
  9. dev_size = 41943040 # 20 Gigabytes 
  10. pe_start = 2048 
  11. pe_count = 5119 # 19.9961 Gigabytes 
  12. [root@localhost ~]# cat /etc/lvm/backup/vg_data |grep -B 2 -A 9 "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" 
  13.  
  14. pv1 { 
  15. id = "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" 
  16. device = "/dev/sdb" # Hint only 
  17.  
  18. status = ["ALLOCATABLE"
  19. flags = [] 
  20. dev_size = 41943040 # 20 Gigabytes 
  21. pe_start = 2048 
  22. pe_count = 5119 # 19.9961 Gigabytes 

让我们先使用pvcreate --test进行试运行:

  1. [root@localhost ~]# pvcreate --test --uuid "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" --restorefile /etc/lvm/archive/vg_data_00002-1587647360.vg /dev/sdc  
  2.   TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated. 
  3.   Couldn't find device with uuid l5rSrt-SRfc-KQNw-Tm29-gx4D-ihBw-Xzum3L. 
  4.   Couldn't find device with uuid v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD. 
  5.   Couldn't find device with uuid UYyDyH-vc6D-XbQ7-ga1X-DKeM-ObLe-tdBLxR. 
  6.   Physical volume "/dev/sdc" successfully created. 

--test 试运行

--uuid 用于指定新创建的物理卷的uuid值。如果没有此选项,将生成随机UUID。在本实验中指定的uuid值是之前删除物理卷的uuid值。

--restorefile 读取由vgcfgbackup生成的存档文件

去掉--test选项,正式创建物理卷:

  1. [root@localhost ~]# pvcreate --uuid "v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD" --restorefile /etc/lvm/archive/vg_data_00002-1587647360.vg /dev/sdc  
  2.   Couldn't find device with uuid l5rSrt-SRfc-KQNw-Tm29-gx4D-ihBw-Xzum3L. 
  3.   Couldn't find device with uuid v6wYGZ-0dGA-8ecB-kec8-r2zv-gCJi-gulSAD. 
  4.   Couldn't find device with uuid UYyDyH-vc6D-XbQ7-ga1X-DKeM-ObLe-tdBLxR. 
  5.   Physical volume "/dev/sdc" successfully created. 
  6. [root@localhost ~]# pvs 
  7.   PV             VG      Fmt  Attr PSize   PFree  
  8.   /dev/nvme0n1p2 cl      lvm2 a--  <19.00g <2.00g 
  9.   /dev/sda       vg_data lvm2 a--  <20.00g     0  
  10.   /dev/sdb       vg_data lvm2 a--  <20.00g     0  
  11.   /dev/sdc       vg_data lvm2 a--  <20.00g <9.99g 
  12. [root@localhost ~]# vgs 
  13.   VG      #PV #LV #SN Attr   VSize   VFree  
  14.   cl        1   2   0 wz--n- <19.00g <2.00g 
  15.   vg_data   3   2   0 wz--n- <59.99g <9.99g 
  16. [root@localhost ~]# lvs -o +devices 
  17.   LV      VG      Attr       LSize  Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert Devices             
  18.   root    cl      -wi-ao---- 15.00g                                                     /dev/nvme0n1p2(512) 
  19.   swap    cl      -wi-ao----  2.00g                                                     /dev/nvme0n1p2(0)   
  20.   lv_data vg_data -wi-a----- 25.00g                                                     /dev/sda(0)         
  21.   lv_data vg_data -wi-a----- 25.00g                                                     /dev/sdc(0)         
  22.   lv_log  vg_data -wi-a----- 25.00g                                                     /dev/sdb(0)         
  23.   lv_log  vg_data -wi-a----- 25.00g       

恢复卷组

然后使用lvm的备份还原卷组。首先加入--test试运行一下:

  1. [root@localhost ~]# vgcfgrestore --test -f /etc/lvm/backup/vg_data vg_data 
  2.   TEST MODE: Metadata will NOT be updated and volumes will not be (de)activated. 
  3.   Volume group vg_data has active volume: lv_log. 
  4.   Volume group vg_data has active volume: lv_data. 
  5.   WARNING: Found 2 active volume(s) in volume group "vg_data"
  6.   Restoring VG with active LVs, may cause mismatch with its metadata. 
  7. Do you really want to proceed with restore of volume group "vg_data", while 2 volume(s) are active? [y/n]: y 
  8.   Restored volume group vg_data. 

下面正式运行一下,去掉--test选项:

  1. [root@localhost ~]# vgcfgrestore -f /etc/lvm/backup/vg_data vg_data 
  2.   Volume group vg_data has active volume: lv_log. 
  3.   Volume group vg_data has active volume: lv_data. 
  4.   WARNING: Found 2 active volume(s) in volume group "vg_data"
  5.   Restoring VG with active LVs, may cause mismatch with its metadata. 
  6. Do you really want to proceed with restore of volume group "vg_data", while 2 volume(s) are active? [y/n]: y 
  7.   Restored volume group vg_data. 

如果卷组和逻辑卷未激活,请使用下面命令激活:

  1. # 扫描卷组 
  2. [root@localhost ~]# vgscan  
  3.   Reading all physical volumes.  This may take a while... 
  4.   Found volume group "cl" using metadata type lvm2 
  5.   Found volume group "vg_data" using metadata type lvm2 
  6. # 激活卷组vg_data 
  7. [root@localhost ~]# vgchange -ay vg_data 
  8.   2 logical volume(s) in volume group "vg_data" now active 
  9. # 扫描逻辑卷 
  10. [root@localhost ~]# lvscan  
  11.   ACTIVE            '/dev/cl/swap' [2.00 GiB] inherit 
  12.   ACTIVE            '/dev/cl/root' [15.00 GiB] inherit 
  13.   ACTIVE            '/dev/vg_data/lv_data' [25.00 GiB] inherit 
  14.   ACTIVE            '/dev/vg_data/lv_log' [25.00 GiB] inherit 

在lvm中,需要执行一些步骤来恢复已删除的物理卷,方法是添加新磁盘并用现有UUID指向新磁盘。

本文转载自微信公众号「Linux就该这么学」,可以通过以下二维码关注。转载本文请联系Linux就该这么学公众号。

 

责任编辑:武晓燕 来源: Linux就该这么学
相关推荐

2020-10-25 17:48:54

LVM系统运维

2015-08-05 15:10:24

UbuntuLVM

2017-12-25 09:50:46

Linux逻辑卷管理文件系统

2009-09-07 09:36:34

2020-10-09 11:15:14

LinuxLVM逻辑卷管理

2023-07-26 07:11:50

LVM底层抽象

2020-10-22 16:48:30

LinuxLVM逻辑卷调整

2010-04-23 18:11:28

Aix镜像

2020-11-27 20:02:17

LVM逻辑卷管理器

2022-04-15 07:51:36

Centos8迁移逻辑卷

2021-12-06 08:00:00

Kubernetes容器数据

2022-09-12 07:59:13

操作系统LVM模式

2023-12-12 13:14:00

LVMLinux逻辑卷管理

2022-01-04 10:54:02

服务器 Lvm系统

2014-06-20 10:51:35

Linux LVM逻辑卷

2009-12-24 16:01:17

redhat Linu

2018-07-31 13:51:16

虚拟机磁盘逻辑卷

2016-08-31 14:16:55

LinuxLVM卷转移

2021-12-14 15:03:58

LVM系统运维

2022-03-28 19:53:24

Linux恢复文件意外删除文件
点赞
收藏

51CTO技术栈公众号