Linux系统LVM扩容报Logical volume datavg/lv_data successfully resized

发布于:2024-05-09 ⋅ 阅读:(104) ⋅ 点赞:(0)

Linux系统LVM扩容报Logical volume datavg/lv_data successfully resized

问题现象

今天在对现有的环境进行扩容的时候报Couldn’t find valid filesystem superblock错误

[root@ZHHALxjspo0db021 ~]# resize2fs /dev/datavg/lv_data
resize2fs 1.45.3 (14-Jul-2019)
resize2fs: Bad magic number in super-block while trying to open /dev/datavg/lv_data
Couldn't find valid filesystem superblock.

问题定位与分析

在遇到该问题后,我这边先对挂载磁盘的存储信息和LVM的vg和lv的信息进行了查看

[root@ZHHALxjspo0db021 ~]# df -h
Filesystem                                                                        Size  Used Avail Use% Mounted on
devtmpfs                                                                           16G     0   16G   0% /dev
tmpfs                                                                              16G  5.0M   16G   1% /dev/shm
tmpfs                                                                              16G   24M   16G   1% /run
tmpfs                                                                              16G     0   16G   0% /sys/fs/cgroup
/dev/mapper/rootvg-lv_root                                                        100G  9.3G   91G  10% /
/dev/sda2                                                                        1014M  312M  703M  31% /boot
/dev/sda1                                                                         200M  5.8M  195M   3% /boot/efi
/dev/mapper/datavg-lv_data                                                        400G  361G   40G  91% /data
/dev/mapper/rootvg-lv_kdump                                                        30G   63M   30G   1% /kdump
/dev/mapper/rootvg-lv_pkg                                                          30G   63M   30G   1% /pkg
/dev/mapper/rootvg-lv_tmp                                                          50G   96M   50G   1% /tmp
/dev/mapper/rootvg-lv_home                                                         50G   36G   15G  71% /home
/dev/mapper/rootvg-lv_hxb_home                                                     50G   84M   50G   1% /home/hxb
/dev/mapper/rootvg-lv_itm                                                          10G   81M   10G   1% /itm
tmpfs                                                                             3.1G     0  3.1G   0% /run/user/0
tmpfs                                                                             3.1G     0  3.1G   0% /run/user/710
103.161.75.43:/686055f00c1c11ef8000fa163eca3664/3a7b18500c2611ef8000fa163eca3664  1.3T   83G  1.2T   7% /ob_backup
[root@ZHHALxjspo0db021 ~]# vgs
  VG     #PV #LV #SN Attr   VSize   VFree
  datavg   1   1   0 wz--n-   1.20t <430.00g
  rootvg   1   8   0 wz--n- 348.80g   12.80g
[root@ZHHALxjspo0db021 ~]# lvs
  LV          VG     Attr       LSize   Pool Origin Data%  Meta%  Move Log Cpy%Sync Convert
  lv_data     datavg -wi-ao---- 800.00g
  lv_home     rootvg -wi-ao----  50.00g
  lv_hxb_home rootvg -wi-ao----  50.00g
  lv_itm      rootvg -wi-ao----  10.00g
  lv_kdump    rootvg -wi-ao----  30.00g
  lv_pkg      rootvg -wi-ao----  30.00g
  lv_root     rootvg -wi-ao---- 100.00g
  lv_swap     rootvg -wi-a-----  16.00g
  lv_tmp      rootvg -wi-ao----  50.00g

根据上面查看的信息,发现lv的扩容是成功,只是由于resize2fs执行失败没有生效。因此就根据报错进行搜索Couldn’t find valid filesystem superblock,在相关文档找到了xfs_growfs和resize2fs两种命令使LV扩容生效,通过对两种命令的详细了解,发现使由于不同的文件系统使用不同的命令。其中xfs_growfs用于xfs文件系统,resize2fs用于ext2、ext3、ext4文件系统。这个时候我们查看现在文件系统使用的xfs,到这里其实我们就大概知道,是使用命令错误了。

[root@ZHHALxjspo0db021 ~]# cat /etc/fstab

#
# /etc/fstab
# Created by anaconda on Mon Jan 22 14:06:27 2024
#
# 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.
#
# After editing this file, run 'systemctl daemon-reload' to update systemd
# units generated from this file.
#
/dev/mapper/rootvg-lv_root /                       xfs     defaults        0 0
UUID=cf581f78-d0ef-4c00-857f-7218c6b0d59a /boot                   xfs     defaults        0 0
UUID=5D28-EC3B          /boot/efi               vfat    defaults,uid=0,gid=0,umask=077,shortname=winnt 0 2
/dev/mapper/rootvg-lv_home /home                   xfs     defaults        0 0
/dev/mapper/rootvg-lv_hxb_home /home/hxb               xfs     defaults        0 0
/dev/mapper/rootvg-lv_itm /itm                    xfs     defaults        0 0
/dev/mapper/rootvg-lv_kdump /kdump                  xfs     defaults        0 0
/dev/mapper/rootvg-lv_pkg /pkg                    xfs     defaults        0 0
/dev/mapper/rootvg-lv_tmp /tmp                    xfs     defaults        0 0
/dev/mapper/datavg-lv_data      /data           xfs     defaults        0 0
103.161.75.43:/686055f00c1c11ef8000fa163eca3664/3a7b18500c2611ef8000fa163eca3664 /ob_backup nfs rw,nfsvers=4.1,sync,lookupcache=positive,hard,timeo=600,wsi                                                                                  ze=1048576,rsize=1048576,namlen=255 0 0

问题处理

在使用xfs_growfs命令后,报如下错误

[root@ZHHALxjspo0db021 ~]# xfs_growfs /dev/mapper/datavg-lv_data
xfs_growfs: /dev/mapper/datavg-lv_data is not a mounted XFS filesystem

根据上面的报错看,是找不到挂在的文件系统,因此就猜测可能使命令参数可能有问题,因此查看帮忙信息,这个时候我们发现xfs_growfs后面使用的mountpoint挂载点。

[root@ZHHALxjspo0db021 ~]# xfs_growfs --help
xfs_growfs: invalid option -- '-'
Usage: xfs_growfs [options] mountpoint

Options:
        -d          grow data/metadata section
        -l          grow log section
        -r          grow realtime section
        -n          don't change anything, just show geometry
        -i          convert log from external to internal format
        -t          alternate location for mount table (/etc/mtab)
        -x          convert log from internal to external format
        -D size     grow data/metadata section to size blks
        -L size     grow/shrink log section to size blks
        -R size     grow realtime section to size blks
        -e size     set realtime extent size to size blks
        -m imaxpct  set inode max percent to imaxpct
        -V          print version information

在把xfs_growfs的参数修改挂载点后,命令执行成功,到这里得到解决。

[root@ZHHALxjspo0db021 ~]# xfs_growfs /data
meta-data=/dev/mapper/datavg-lv_data isize=512    agcount=4, agsize=26213888 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=1, sparse=1, rmapbt=0
         =                       reflink=0
data     =                       bsize=4096   blocks=104855552, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0, ftype=1
log      =internal log           bsize=4096   blocks=51199, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0
data blocks changed from 104855552 to 209715200
[root@ZHHALxjspo0db021 ~]#
[root@ZHHALxjspo0db021 ~]# df -h
Filesystem                                                                        Size  Used Avail Use% Mounted on
devtmpfs                                                                           16G     0   16G   0% /dev
tmpfs                                                                              16G  5.0M   16G   1% /dev/shm
tmpfs                                                                              16G   24M   16G   1% /run
tmpfs                                                                              16G     0   16G   0% /sys/fs/cgroup
/dev/mapper/rootvg-lv_root                                                        100G  9.3G   91G  10% /
/dev/sda2                                                                        1014M  312M  703M  31% /boot
/dev/sda1                                                                         200M  5.8M  195M   3% /boot/efi
/dev/mapper/datavg-lv_data                                                        800G  361G  439G  46% /data
/dev/mapper/rootvg-lv_kdump                                                        30G   63M   30G   1% /kdump
/dev/mapper/rootvg-lv_pkg                                                          30G   63M   30G   1% /pkg
/dev/mapper/rootvg-lv_tmp                                                          50G   95M   50G   1% /tmp
/dev/mapper/rootvg-lv_home                                                         50G   36G   15G  71% /home
/dev/mapper/rootvg-lv_hxb_home                                                     50G   84M   50G   1% /home/hxb
/dev/mapper/rootvg-lv_itm                                                          10G   81M   10G   1% /itm
tmpfs                                                                             3.1G     0  3.1G   0% /run/user/0
tmpfs                                                                             3.1G     0  3.1G   0% /run/user/710
103.161.75.43:/686055f00c1c11ef8000fa163eca3664/3a7b18500c2611ef8000fa163eca3664  1.3T   83G  1.2T   7% /ob_backup

问题总结

这个问题主要使自己平时安装操作系统使用的都是ext的文件使用,没有注意到xfs文件系统对于逻辑卷的扩容还需要特殊的命令才可以生效。问题虽然解决,但是也顺便记录一下自己解决问题的过程。