生产紧急问题可私信博主解决
背景:
朋友跟我说他的centos7服务器开不开机了,给了我一张图片
他告诉运维通过xfs_repair修复无效,依旧启动不了
原因分析
从以上图片可知系统进入了dracut模式,很明显的报错/dev/mapper/centos-root does not exist
找不到root分区了,/dev/mapper 字符明确告诉我们系统分区是靠lvm管理的,通过以下分析我们找到了答案
/dev/mapper/看不到任何设备 lvs/vgs已经看不到任何的信息 vgscan也扫不到任何vg信息
该问题就是lvm分区信息丢失导致系统无法正常挂载丢失
解决思路
1.既然是lvm分区的问题,那就着手如何对lvm的分区信息进行恢复
2.正常的lvm是对逻辑分区做备份的,备份文件位置/etc/lvm/backup 一般的问题可以直接通过备份文件将分区恢复,直接执行命令 vgcfgrestore centos
3但该机器恰恰是根分区损坏,备份文件也找不到
4.通过磁盘前几个扇区找有用的信息
执行
1.第一步先做一个livecd,保证我们正常分析
2.分析磁盘扇区信息
dd if=/dev/sdb3 bs=512 count=10 | hexdump -C
好在磁盘还保存有分区信息,说明还有救
3.编写vg恢复配置文件
如下为一个/etc/lvm/backup/pool的配置实例:
# Generated by LVM2 version 2.02.42 (2008-10-26): Sat Sep 25 17:36:30 2010
contents = "Text Format Volume Group"
version = 1
description = "Created *after* executing 'lvcreate --name block --size 300G pool'"
creation_host = "zhuweiR30" # Linux zhuweiR30 2.6.28-storix #1 SMP Thu Dec 24 17:25:02 CST 2009 i686
creation_time = 1285407390 # Sat Sep 25 17:36:30 2010
pool {
id = "0Lm9dz-sIeu-t2Ho-qIBR-lD2P-dcbK-K1U4zW"
seqno = 2
status = ["RESIZEABLE", "READ", "WRITE"]
flags = []
extent_size = 8192 # 4 Megabytes
max_lv = 0
max_pv = 0
physical_volumes {
pv0 {
id = "rewaTQ-vKaK-PzWs-H14L-a2Qz-hV62-CcIHqT"
device = "/dev/sdb" # Hint only
status = ["ALLOCATABLE"]
flags = []
dev_size = 21484367872 # 10.0044 Terabytes
pe_start = 384
pe_count = 2622603 # 10.0044 Terabytes
}
}
logical_volumes {
block {
id = "ryg1Or-e1C3-ooKV-0XMM-jKSN-g0EM-dXky7G"
status = ["READ", "WRITE", "VISIBLE"]
flags = []
segment_count = 1
segment1 {
start_extent = 0
extent_count = 76800 # 300 Gigabytes
type = "striped"
stripe_count = 1 # linear
stripes = [
"pv0", 0
]
}
}
}
}
根绝信息编写我们的配置文件
4.命令执行
vgcfgrestore centos -f .conf
5.查看信息
vgs/lvs信息恢复
6.重启
reboot重启恢复正常