centos 6 lvm 扩容超过16T的一个坑(unknown device)

本文记录了一次从16T扩展LVM至22T的实际操作过程,包括分区、格式化、创建PV、VG及LV等步骤,并详细讲述了在使用resize2fs过程中遇到的32位文件系统限制问题及其解决方案。

首先创建lvm(2个8T的盘,由于硬件制造商的原因8T的盘在操作系统识别来看并没有8T)

parted /dev/sdb
parted /dev/sdc
    (parted) mklabel gpt                     #标记为gpt格式的硬盘
    (parted) mkpart                            #分区
    文件系统类型?  [ext2]? ext4       #ext4文件系统
    起始点? 0
    结束点?-1
    toggle lvm                                     #给分区打上lvm标签
mkfs.ext4 /dev/sdb1                        #格式化
mkfs.ext4 /dev/sdc1                        #格式化
tune2fs -m 1 /dev/sdb1                   #调整系统为root用户保留的空间,默认为5%
tune2fs -m 1 /dev/sdc1

pvcreate  /dev/sdb1 /dev/sdc1                         #创建pv
vgcreate vr_vg  /dev/sdb1  /dev/sdc1              #创建vg
vgdisplay                                                         #查看vg所有的PE,默认4M为一个PE
lvcreate -l 3815442 -n lv_vr vg_vr                   #将所有的空间创建一个lv
#第一次创建pv就这样结束了,并没有遇见任何坑;但是第二次扩展的时候却遇见了一个大坑

#由于业务的变迁,16T的硬盘已经不再够用,需要将剩下的一块盘(8T)扩展到lvm中
扩展lvm:
    首先将硬盘分区格式(参照上面的步骤)
    pvcreate  /dev/sdd1
    vgvgextend   vg_vr  /dev/sdd1                                          #扩展vg
    lvresize  -l  +1907720  /dev/mapper/vr_vg-vr_lv               #扩展lv

    执行lvdisplay可以看见lv已经扩展了,但是使用df -hl查看的时候分区还是这么大,这时候我执行 resize2fs /dev/mapper/vr_vg-vr_lv 刷新逻辑卷的时候 "坑出现了"

    $ resize2fs  /dev/mapper/vr_vg-vr_lv
        resize2fs: New size too large to be expressed in 32 bits                            
        #报错了,说32文件系统最大只支持16T的分区,emmm 出现问题就要解决,没办法只能 百度了结果没有找到换Google试试,最后总算找到了解决办法

    https://askubuntu.com/questions/779754/how-do-i-resize-an-ext4-partition-beyond-the-16tb-limit      
    #Google找到的文档,国内也可以访问

    更具文档的相关描述是因为 resize2fs 低版本有个bug(其实也不算bug),既然知道了原因那么接开始干,将resize2fs升级为最新版本

    umount /dev/mapper/vr_vg-vr_lv            #先把挂载去掉
    git clone -b v1.44.2 https://git.kernel.org/pub/scm/fs/ext2/e2fsprogs.git e2fsprogs && cd e2fsprogs       
        #下载resize2fs 版本必须高于1.44
    ./configure                               #检查依赖关系(一般都不会遇见什么坑)
    make                                       #编译,别执行make install

    cd resize/
    ./resize2fs /dev/mapper/vr_vg-vr_lv               #运行这条命令会把32位文件系统转换为64为文件系统(分区小于16T不会装换),并且会扩大超级块的数量
    #转换完之后提示需要使用e2fsck -f 检查分区

    e2fsck -f  /dev/mapper/vr_vg-vr_lv              #擦,又报错,说e2fsck不支持64位的文件系统, emmmmm, 想了一下可能 e2fsck 和 resize2fs 一样版本过低不支持64位文件系统,用最新版本试试,e2fsck和resize2fs是由一个包提供的
    cd ..
    cd e2fsck/
    ./e2fsck  /dev/mapper/vr_vg-vr_lv                    #果然使用新版本的e2fsck就可以了
    ./resize/resize2fs /dev/mapper/vr_vg-vr_lv      #然后刷新文件系统
    df -hl                                                                #看见22T分区大小(硬件制造商的锅)

    #到这儿我心想应该没问题了,结果更大的坑还在后面等着我
    执行 lvdisplay 看看没问题
    执行 vgdisplay 看看没问题
    执行 pvdisplay 看看.....坑来了

    --- Physical volume ---
    PV Name               /dev/sdb1
    VG Name               vr_vg
    PV Size               7.28 TiB / not usable 1.30 MiB
    Allocatable           yes (but full)
    PE Size               4.00 MiB
    Total PE              1907721
    Free PE               0
    Allocated PE          1907721
    PV UUID               PCFu9x-SEGH-W941-0hc9-NHBb-0Nox-QdT79y

    --- Physical volume ---
    PV Name               /dev/sdc1
    VG Name               vr_vg
    PV Size               7.28 TiB / not usable 1.30 MiB
    Allocatable           yes (but full)
    PE Size               4.00 MiB
    Total PE              1907721
    Free PE               0
    Allocated PE          1907721
    PV UUID               VHZUiE-in7U-RljG-WrvU-rO5u-lLf4-gpuMqE

    --- Physical volume ---
    PV Name               unknown device                                              #未识别的设备????这是什么情况
    VG Name               vr_vg
    PV Size               7.28 TiB / not usable 4.37 MiB
    Allocatable           yes (but full)
    PE Size               4.00 MiB
    Total PE              1907720
    Free PE               0
    Allocated PE          1907720
    PV UUID               x38382-rjUg-Fj5B-h5hC-LvrK-tq2h-HcZrkJ

#没办法解决了半天没还是解决不了.....,重启一下试试,结果一重启机器起不来了,叫机房的人看看....最后发现是系统检查 /dev/mapper/vr_vg-vr_lv 报错了,果然是个坑啊,没办法机房的人解决不了,自己去一下机房解决吧!!!

#来到机房第一件事进单用户模式,结果进不去...原因是因为fsck检查/dev/mapper/vr_vg-vr_lv失败

/dev/mapper/vr_vg-vr_lv                   /data                   ext4    defaults       1 2                #/etc/fstab配置

硬盘检查不过进不了系统,那么就只能把服务器的系统盘卸下来挂载到其他的服务器上,修改挂载盘的 etc/fstab 把挂载lvm的哪行去掉,然后放回原来的服务器

#做完这些操作之后成功进入系统....但是检查lvm却发现/dev/mapper/不存在vr_vg-vr_lv.... 这是什么情况???

lvdisplay                 #没问题一切正常
vgdisplay                 #没问题一切正常
pvdisplay                 #/dev/sdd还是显示unknown device

那么先解决unknown device这个问题吧:
  首先肯定要卸掉/dev/sdd这个盘:
    vgreduce vr_vg --removemissing --force              #强行卸掉vr_vg里面未知的设备

    lvdisplay             #查看lv大小还是22T,但是现在两块盘只有16T,所有要将lvm恢复成两块盘时候的大小

  恢复lvm:
    cd /etc/lvm/          #在lvm目录下有两个主要的目录 archive:保存lvm每次发生改变的源数据  backup:lvm的备份文件
    cd archive/           #找到lvm还是两块盘的时候的备份

    cp vr_vg_00002-1529881488.vg ../backup/     #vgcfgrestore 恢复时只会在这个目录查找
    cd ../backup/
    mv vr_vg vr_vg.back1                        #备份当前的vr_vg(vg的名字)
    mv vr_vg_00002-1529881488.vg vr_vg
    vgcfgrestore vr_vg                          #恢复备份

    lvdisplay                             #查看lv大小已经恢复成16T,现在需要把剩下的那块盘加上

    首先还是将硬盘分区格式,然后使用pvcreate创建pv,使用vgextend扩展vg,使用lvresize扩展lv

    扩展完后/dev/mapper/还是不存在vr_vg-vr_lv,那是因为vg还没有激活

    vgchange -ay vr_vg            #激活vg,这个时候再去查看/dev/mapper/发现vr_vg-vr_lv已经有了,但是这时候还不能直接使用,因为刚加了的盘还没有执行resize2fs

    ./e2fsck -f  /dev/mapper/vr_vg-vr_lv            #先检查硬盘(因为lv已经扩展过一次了所以会提示实际的块小于应有的块,是否检查,回复 y 就行,当检查到所有的块之后会询问你是否将这些加入现有分区,回复y即可)

    ./resize/resize2fs /dev/mapper/vr_vg-vr_lv      #刷新lv大小

    最后刷新完之后,一切正常,由于lvm的线性存储,数据也没有丢失

  最后:
    修改
      /etc/fstab配置/dev/mapper/vr_vg-vr_lv                   /data                   ext4    defaults       0 0

转载于:https://blog.51cto.com/hongchen99/2126363

当您尝试挂载一个存储设备时,如果系统返回类似“未知的文件系统类型‘LVM2_mem’”这样的错误消息,这通常表明存在误解或配置问题。实际上,“LVM2_member”并不是一种真正的文件系统类型,而是一种标识逻辑卷管理(Logical Volume Manager, LVM)结构成员的标签。 以下是对此现象的具体解释及解决办法: --- ### 1. **理解 LVMLVM2_member** - **什么是 LVM**? LVM 是一种允许动态调整分区大小的技术框架。它通过将物理磁盘划分为物理卷(PV),再组合成卷组(VG),最终分配给逻辑卷(LV)的方式提供更灵活的空间管理能力。 - **为什么会出现 ‘LVM2_member’ 标记?** 这是因为底层的块设备已加入到 LVM 的体系中,作为组成更高层逻辑卷的基础资源。“LVM2_member”只是说明此块设备参与构建了一个更大的虚拟空间单元,并不代表可以直接像常规文件系统那样直接挂载使用。 --- ### 2. **解决问题的方法** 既然不能简单地以 “LVM2_member” 类型去挂载该磁盘区域,那么正确的做法应该是按照下面几个步骤找到并操作属于它的真正可用部分——即那些已经被格式化的逻辑卷上的文件系统: #### 步骤 A:确认是否安装了必要的软件包 确保操作系统具备支持 lvm 功能的相关工具集,比如 device-mapper 和 lvm2 库等。如果没有的话请先行部署: ```shell sudo apt-get install lvm2 # Debian/Ubuntu系列 # 或者对于 RedHat/CentOS 用户来说则是运行 yum/dnf: sudo yum install lvm2 ``` #### 步骤 B:扫描现有 PV/VG/LVs 并激活它们 执行以下命令让内核识别出所有的逻辑体积及其归属关系: ```shell pvscan && vgscan && lvchange -ay ``` 上述指令分别用于发现所有物理卷、搜索存在的卷组并且启动全部处于非活动状态下的逻辑卷实例们。 #### 步骤 C:定位目标 LVs 所采用的实际 FS 种类 借助 `lvdisplay` 查看每个逻辑卷详情后便可得知其各自对应的挂载路径还有属性特征值当中包含有具体的文件系统种类信息字段如 ext4/xfs 等等... 最后再依据所得结果实施标准流程挂接动作啦~ 例如假设其中一个名为 mydata_lv 的逻辑卷采用了 EXT4 文件系统,则按如下方式接入服务器环境之内即可: ```shell sudo mount /dev/mapper/<volume_group_name>-mydata_lv <target_mount_point> ``` --- ### 总结 记住啊朋友,下次要是碰见这种提示说啥叫 "unknown filesystem type 'LVM2_member'" 啦之类的别慌神儿~只需冷静下来一步步跟着上面介绍过的思路走就行咯!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值