找回密码
 立即注册
首页 业界区 业界 arm环境vg损坏mysql数据库恢复---惜分飞

arm环境vg损坏mysql数据库恢复---惜分飞

宓碧莹 昨天 11:30
联系:手机/微信(+86 17813235971) QQ(107644445)
1.jpeg

标题:arm环境vg损坏mysql数据库恢复
作者:惜分飞©版权所有[未经本人同意,不得以任何形式转载,否则有进一步追究法律责任的权利.]
国庆节期间接到朋友咨询,原先在vg中的磁盘被重新pvcreate了,想恢复原磁盘中的mysql数据库
2.png

通过分析系统的history日志,发现操作不是简单的pvcreate,我简单梳理下操作步骤
故障之前磁盘情况 
[root@0002 ~]# lsblkNAME                  MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTsr0                    11:0    1 1024M  0 rom  vda                   253:0    0  200G  0 disk ├─vda1                253:1    0  600M  0 part /boot/efi├─vda2                253:2    0    1G  0 part /boot└─vda3                253:3    0 38.4G  0 part   ├─klas-root         252:0    0 34.4G  0 lvm  /  └─klas-swap         252:1    0    4G  0 lvm  [SWAP]vdb                   253:16   0 1000G  0 disk └─vdb1                253:17   0  500G  0 part   └─mysql-mysql--mycg 252:2    0  500G  0 lvm  /mysql
这里可以看到出来vdb磁盘一共1000G,分区vdb1 为500G,然后这500G加入到vg中并分配了lv.

vdb磁盘现状
[root@0002 mysql]# lsblk /dev/vdbNAME                  MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTvdb                   253:16   0 1000G  0 disk └─vdb1                253:17   0 1000G  0 part  Disk /dev/vdb: 1000 GiB, 1073741824000 bytes, 2097152000 sectorsUnits: sectors of 1 * 512 = 512 bytesSector size (logical/physical): 512 bytes / 512 bytesI/O size (minimum/optimal): 512 bytes / 512 bytesDisklabel type: dosDisk identifier: 0x5a6aaeee Device     Boot Start        End    Sectors  Size Id Type/dev/vdb1        2048 2097151999 2097149952 1000G 8e Linux LVM
这里基本上可以确定,vdb1磁盘分区从以前的500G变成了1000G(也就是说被重新分区了,后续和现场沟通确认进行了重新分区操作)
通过history日志追述大概的操作过程 
898  [2025-09-28 11:55:13][root]fdisk -l899  [2025-09-28 11:55:21][root]df -h900  [2025-09-28 11:56:41][root]lsblk901  [2025-09-28 11:59:44][root]fdisk /dev/vdb902  [2025-09-28 12:00:46][root]partprobe /dev/vdb903  [2025-09-28 12:00:50][root]pvresize /dev/vdb1904  [2025-09-28 12:00:56][root]df -h905  [2025-09-28 12:01:25][root]vgdisplay mysql906  [2025-09-28 12:01:40][root]lsblk907  [2025-09-28 12:02:05][root]sudo partprobe /dev/vdb908  [2025-09-28 12:02:10][root]pvresize /dev/vdb1909  [2025-09-28 12:02:27][root]sudo pvresize /dev/vdb1910  [2025-09-28 12:03:07][root]sudo pvcreate /dev/vdb1911  [2025-09-28 12:03:22][root]sudo pvscan912  [2025-09-28 12:03:30][root]sudo pvdisplay913  [2025-09-28 12:05:37][root]parted /dev/vdb914  [2025-09-28 12:06:11][root]pvresize /dev/vdb1915  [2025-09-28 12:06:15][root]lsblk916  [2025-09-28 12:09:48][root]lvextend -l +100%FREE /dev/mysql/mysql--mycg917  [2025-09-28 12:10:00][root]cd /dev/mysql/918  [2025-09-28 12:10:01][root]ll919  [2025-09-28 12:10:20][root]pwd920  [2025-09-28 12:10:32][root]lvextend -l +100%FREE /dev/mysql/mysql-mycg921  [2025-09-28 12:10:55][root]lsblk /dev/vdb
基本上可以确定9月28日先进行了fdisk分区操作,然后尝试pvresize 操作[应该不会成功,因为重新分区导致pv信息丢失],然后进行了pvcreate之后再次进行parted分区操作,再pvresize,lvextend操作[同理pv信息丢失应该不会成功],然后10月5日继续进行的部分操作
956  [2025-10-05 08:29:27][root]umount /mysql957  [2025-10-05 08:29:38][root]lsof /mysql958  [2025-10-05 08:29:58][root]service mysqld stop959  [2025-10-05 08:30:02][root]umount /mysql960  [2025-10-05 08:30:05][root]lsof /mysql961  [2025-10-05 08:30:23][root]cd /962  [2025-10-05 08:30:25][root]umount /mysql963  [2025-10-05 08:30:34][root]pvcreate --force /dev/vdb1964  [2025-10-05 08:30:47][root]vgextend mysql /dev/vdb1965  [2025-10-05 08:31:02][root]df -h966  [2025-10-05 08:31:33][root]pvdisplay /dev/vdb1967  [2025-10-05 08:31:41][root]pvcreate --force /dev/vdb1968  [2025-10-05 08:32:11][root]lvs | grep mysql-mysql--mycg969  [2025-10-05 08:32:19][root]dmsetup ls | grep mysql970  [2025-10-05 08:32:38][root]fuser /dev/vdb1971  [2025-10-05 08:32:41][root]lsof /dev/vdb1972  [2025-10-05 08:32:50][root]pvcreate --force /dev/vdb1973  [2025-10-05 08:33:14][root]reboot974  [2025-10-05 08:36:23][root]pvcreate --force /dev/vdb1975  [2025-10-05 08:36:47][root]lvdisplay /dev/mapper/mysql-mysql--mycg976  [2025-10-05 08:36:53][root]vgextend mysql /dev/vdb1977  [2025-10-05 08:37:10][root]lvextend -l +100%FREE /dev/mysql/mysql--mycg
初步看,应该是先尝试umount /dev/vdb1,但是没有成功,然后直接reboot重启了主机,起来之后,进行了pvcreate[操作成功],vgextend,lvextend等操作[失败,因为vg里面的之前的pv信息已经丢失],而且之前lv无法mount成功,数据库文件/备份均在这个lv里面,而且从库很久之前没有正常同步.基于这样的情况,就一定要对vdb磁盘中数据进行恢复.查看操作系统信息,确认是arm系统
3.png

由于arm系统一般工具均无法正常解析,只能让客户把磁盘挂载到x86环境进行处理,通过专业恢复工具解析,运气不错可以直接读取数据
4.png

传输数据到客户服务器中,并成功启动mysql,客户测试业务没有任何问题,数据完整恢复
5.png


  • docker回收和mysql备份导入导致数据丢失恢复
  • pg误删除数据恢复(PostgreSQL delete数据恢复)
  • redhat系列7/8进入单用户模式
  • fio测试io,导致磁盘文件系统损坏故障恢复
  • Failed to open \EFI\redhat\grubx64.efi – Not Found 故障处理
  • 可能是 tempdb 空间用尽或某个系统表不一致故障处理
  • 中文环境显示AR8MSWIN1256(阿拉伯语字符集)
  • VMware勒索加密恢复(vmdk勒索恢复)
  • 第一例Oracle 21c恢复咨询
  • pg启动报invalid checkpoint record处理
  • sql server数据库“正在恢复”故障处理
  • 删除数据库文件并部分覆盖情况下Oracle恢复

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册