Linux系统如何应对磁盘过大无法挂载的问题 (磁盘太大linux挂不上)

Introduction

随着科技的不断发展,计算机的存储容量不断扩大。然而,当我们面临大型存储设备时,可能会遇到一些令人头痛的问题,例如磁盘过大无法挂载。本文将着重介绍如何在Linux系统中应对这种情况。

Part 1 – 了解磁盘大小的限制

在开始解决问题之前,我们需要了解Linux系统中磁盘大小的限制。在32位系统中,由于寻址空间的限制,操作系统只能寻址更大为4GB的内存。类似地,在32位系统中,由于寻址空间的限制,更大支持的磁盘大小为2TB。因此,在处理大型存储设备时,我们应该考虑升级到64位操作系统。

Part 2 – 解决磁盘过大无法挂载的问题

当我们面临磁盘过大无法挂载的问题时,可以采取以下解决办法:

2.1 使用GPT分区表

在使用MBR分区表时,更大支持的磁盘大小为2TB。而在使用GPT分区表时,更大支持的磁盘大小为9.4ZB(1ZB=1024EB)。因此,使用GPT分区表可以避免磁盘过大无法挂载的问题。

要使用GPT分区表,请使用以下命令:

“`

# fdisk /dev/sdX

“`

其中,sdX是磁盘的名称,例如sda或sdb等。

输入“g”命令会创建一个新的GPT分区表。接下来,您可以使用“n”命令创建一个新分区,并使用“w”命令保存更改并退出fdisk。

请注意,在使用GPT分区表时,您需要安装GRUB2以启动系统。

2.2 使用LVM

另一种解决磁盘过大无法挂载的问题的方法是使用逻辑卷管理(LVM)。LVM是一种在逻辑上管理硬盘分区的技术,可以将多个物理分区组合成一个逻辑卷。这使得我们可以轻松地扩展文件系统而无需重新分配磁盘分区。

要使用LVM,请先创建物理卷(PV),然后将它们组合成卷组(VG),最后将卷组分配给逻辑卷(LV)。您可以在创建逻辑卷之前动态地添加或删除物理卷,这使得LVM非常灵活。

2.3 使用分散存储

另一种解决磁盘过大无法挂载的方法是使用分散存储。这是一种将数据存储在多个磁盘上的技术,可以提高存储容量,并提高数据的可靠性。当一个磁盘出现故障时,其他磁盘可以自动接管所有数据。

使用分散存储时,您需要一个软件层来管理数据传输和恢复,例如RD(磁盘阵列Redundant Array of Independent Disks)或ZFS(Z File System)。这些软件层提供了多种方法来同步和复制数据,可以根据您的需求进行选择。

Part 3 – 结论

对于Linux中磁盘过大无法挂载的问题,有几种解决方法可供选择。您可以使用GPT分区表、LVM或分散存储来解决这个问题。使用这些技术,您可以轻松地处理大型存储设备,并持续地进行扩展,以满足您的需求。

相关问题拓展阅读:

linux磁盘重新挂载?

只要6步!Linux系统下挂载硬帆顷仿春盘不再困扰你态大陆!

linux 重新挂载需要先卸载再重新挂载,如果要一条命令可以通过&&符号将两个命令组合到一个命令里,例如:

umount -l /mnt/test && mount -o ro /dev/hda1  /mnt/test

linux中挂载命令是mount,卸载是umount,在命令行中使用&&可以将多条命令组合成一条命令并顺序执行,以达到快速执行的目的。

扩展资料

linux挂载命令mount的用法介岁源笑绍:

1、语法

mount device dir

2、参数说明:

-V:显示程序版本

-h:显示辅助讯息

-v:显示裂配较讯息,通常和 -f 用来除错。

-a:将 /etc/fstab 中定义的所有档案系统挂上。

-F:这个命令通常和 -a 一起使用,它会为每一个 mount 的动作产生一个行程负责执行。在系统需要挂上大量 NFS 档案系统时可以加快挂上的动作。

-f:通常用在除错的用途。它会使 mount 并不执行实际挂上的动作,而是模拟整个挂上的过程。通常会和 -v 一起使用。

-n:一般而言,mount 在挂上后会在 /etc/mtab 中写入一笔资料。但在系统中没有可写入档案系统存在的情况下可以用这乎含个选项取消这个动作。

VMware虚拟机中,Linux系统下挂载、卸载新硬盘的方法

装载:

1、启动vm,选择vm->Settings,按向导旅册添加一块SCSI磁盘。进入Linux系统。

2、 fdisk -l 会看到有一块新的设置,如果你先前有一块硬盘(sda1, sda3…),新加的这块应该是(/dev/sdb)。 (如果添加的第二块硬盘是IDE硬盘,应该看到hdb,如果是姿改SCSI硬盘,看到的就是应该sdb)

# fdisk -l

Disk /dev/sda: 8589 MB,bytes

255 heads, 63 sectors/track, 1044 cylinders

Units = cylinders of* 512 =bytes

Device Boot StartEnd Blocks Id System

/dev/sda1 * Linux

/dev/sda+ 83 Linux

Disk /dev/sdb: 8589 MB,bytes

255 heads, 63 sectors/track, 1044 cylinders

Units = cylinders of* 512 =bytes

Disk /dev/sdb doesn’t contain a valid partition table

3、分区:

# fdisk /dev/sdb

Device contains neither a valid DOS partition table, nor Sun, SGI or OSF disklabel

Building a new DOS disklabel. Changes will remain in memory only,

until you decide to write them. After that, of course, the previous

content won’t be recoverable.

The number of cylinders for this disk is set to 1044.

There is nothing wrong with that, but this is larger than 1024,

and could in certain setups cause problems with:

1) software that runs at boot time (e.g., old versions of LILO)

2) booting and partitioning software from other OSs

(e.g., DOS FDISK, OS/2 FDISK)

Warning: invalid flag 0x0000 of partition table 4 will be corrected by w(rite)

Command (m for help): m ##在这里按m ,就会输出帮助;

Command action

a toggle a bootable flag

b edit bsd disklabel

c toggle the dos compatibility flag

d delete a partition ##这是删除一个分区的动作;

l list known partition types ##:l是列出分区类型,以拆册宏供我们设置相应分区的类型;

m print this menu

n add a new partition ##添加一个分区;

o create a new empty DOS partition table

p print the partition table ##p列出分区表;

q quit without saving changes ##不保存退出;

s create a new empty Sun disklabel

t change a partition’s system id ##t 改变分区类型;

u change display/entry units

v verify the partition table

w write table to disk and exit ##把分区表写入硬盘并退出;

x extra functionality (experts only) ##扩展应用,专家功能;

Command (m for help): n

Command action

e extended ##扩展分区

p primary partition (1-4) ##选p建主分区

p

Partition number (1-4): 1

First cylinder (, default 1): ##注:这个就是分区的Start 值;这里更好直接按回车,如果你输入了一个非默认的数字,会造成空间浪费;

Using default value 1

Last cylinder or +size or +sizeM or +sizeK (, default 17849): 8920

Using default value 500

##这个是定义分区大小的,+200M 就是大小为200M ;当然你也可以根据上面提示的单位cylinder的大小来算,然后来指定 End的数值,在fdisk –l命令中可以看到Units = cylinders of* 512 =bytes,这个就是单位cylinder的大小,我这里选的End的数值是8920,正好是总大小的一半,71G左右

##然后再来建一个主分区

Command (m for help): n

Command action

e extended

p primary partition (1-4)

p

Partition number (1-4): 2

First cylinder (, default 8921):8921

Using default value 8921

Last cylinder or +size or +sizeM or +sizeK (, default 17849):17849

Using default value 17849

##最后保存并退出,切记,一定要保存,不然不会生效的。

Command (m for help): w

The partition table has been altered!

Calling ioctl() to re-read partition table.

Syncing disks.

##使用fdisk –l命令来查看磁盘状况:

# fdisk -l

Disk /dev/sda: 8589 MB,bytes

255 heads, 63 sectors/track, 1044 cylinders

Units = cylinders of* 512 =bytes

Device Boot StartEnd Blocks Id System

/dev/sda1 * Linux

/dev/sda+ 83 Linux

Disk /dev/sdb: 8589 MB,bytes

255 heads, 63 sectors/track, 1044 cylinders

Units = cylinders of* 512 =bytes

Device Boot StartEnd Blocks Id System

/dev/sdb+ 83 Linux

/dev/sdb+ 83 Linux

##磁盘/dev/sdb已经被划分为2个分区,每个分区大小大概是71G左右。

##在挂载文件系统之前,需要将/dev/sdb1和/dev/sdb2重新用mkfs -t ext3 命令格式化一下,否则在挂载时会报错。

4、格式化分区:使用mkfs.ext3 /dev/sdb命令格式化磁盘 注:也可以使用mkfs -t ext3 /dev/sdb命令

# mkfs -t ext3 /dev/sdb1 ##指将该磁盘格式化成ext3文件系统

mke2fs 1.39 (29-May-2023)

Filesystem label=

OS type: Linux

Block size=4096 (log=2)

Fragment size=4096 (log=2)

inodes,blocks

blocks (5.00%) reserved for the super user

First data block=0

Maximum filesystem blocks=

64 block groups

32768 blocks per group,fragments per group

16384 inodes per group

Superblock backups stored on blocks:

, 98304,,,,,,

Writing inode tables: done

Creating journal (32768 blocks): done

Writing superblocks and filesystem accounting information: done

This filesystem will be automatically checked every 31 mounts or

180 days, whichever comes first. Use tune2fs -c or -i to override.

补充:挂载

挂载文件系统,目前有两种方法:

一是通过 mount 来挂载,使用mount挂载系统,一旦系统重启之后就需要重新挂载。

二是通过/etc/fstab文件来开机自动挂载。

我把/dev/sdb1挂载到/test下

# mkdir /test ## 首先建立挂载的目录test

(或者# cd /

# mkdir test

)

# df –h ##挂载前的分区

FilesystemSize Used Avail Use% Mounted on

/dev/mapper/VolGroup00-LogVol00

.7G 5.8G 576M 92% /

/dev/sda 99M 12M 82M 13% /boot

tmpfs 233MM 0% /dev/shm

# mount /dev/sdb1 /test

# df –h ##挂载后的分区

FilesystemSize Used Avail Use% Mounted on

/dev/mapper/VolGroup00-LogVol00

.7G 5.8G 576M 92% /

/dev/sda 99M 12M 82M 13% /boot

tmpfs 233MM 0% /dev/shm

/dev/sdb7.9G 147M 7.4G 2% /test

6、通过/etc/fstab文件来开机自动挂载(不然重启电脑后系统将不会保存之前的挂载操作):

# vi /etc/fstab

/dev/VolGroup00/LogVol00 /ext3 defaults

LABEL=/boot/boot ext3 defaults

devpts /dev/pts devpts gid=5,mode=

tmpfs /dev/shm tmpfs defaults

proc /proc proc defaults

sysfs /sys sysfs defaults

/dev/VolGroup00/LogVol01 swap swap defaults

/dev/sdb/testextdefaults1 1

/dev/sdb/testextdefaults1 1

# Beginning of the block added by the VMware software

.host:/ /mnt/hgfs vmhgfs defaults,ttl=

# End of the block added by the VMware software

之一字段:设备名,在这里表示是文件系统; 有时我们把挂载文件系统也说成挂载分区;

第二字段:文件系统的挂载点;

第三字段:文件系统类型;

第四字段:mount 命令的选项,和mount 中的-o 同理;defaults包括这些选项 rw, suid, dev, exec, auto, nouser, async;

第五字段:表示文件系统是否需要dump 备份,1是需要,0 是不需要;

第六字段: 是否在系统启动时,通过fsck磁盘检测工具来检查文件系统,1是需要,0是不需要,2是跳过;

卸载:

# umount /dev/sdb1

# df -h

FilesystemSize Used Avail Use% Mounted on

/dev/mapper/VolGroup00-LogVol00

.7G 5.8G 576M 92% /

/dev/sda 99M 12M 82M 13% /boot

tmpfs 233MM 0% /dev/shm

补充知识:

1. mount可以用来挂载什么:

不同的操作系统使用不同的文件系统格式。MS-DOS支持FAT16文件系统,Windows98支持FAT16、FAT32文件系 统,WindowsNT支持FAT16、NTFS文件系统,Windows2023则支持FAT16、FAT32、NTFS三种文件系统格式,现在的xp 可以支持FAT32,NTFS,现在最新版本的windows 7 引入了新的WinFS文件系统。 而 Linux差不多支持所有的文件系统格式,但一般使用ext2或ext3文件系统。很多用户使用的是windows操作系统,如果想在运行的Linux下 访问其它文件系统中的资源的话,就要用Linux mount命令来实现。

2. mount使用格式:

mount命令

说明:

必须是一个已经存在的目录,这个目录可以不为空,但挂载后这个目录下以前的内容将不可用,umount以后会恢复正常。

可以是一个分区,一个u设备,光驱,软盘,网络共享等。

常见参数说明:

Mount 挂载文件系统使用帮助

参数 说明

挂载指定的设备类型:adfs, affs, autofs, coda, coherent, cramfs,

devpts, efs, ext, ext2, ext3, hfs, hpfs, iso9660, jfs, minix,

msdos, ncpfs, nfs, nfs4, ntfs, proc, qnx4, ramfs, reiserfs,

romfs, bfs, sysv, tmpfs, udf, ufs, umsdos, vfat, xenix, xfs,

xiafs

一般文件类型,可以不需要指定就可以有相同自动检测(adfs, bfs,

cramfs, ext, ext2, ext3, hfs, hpfs, iso9660, jfs, minix, ntfs,

qnx4, reiserfs, romfs, udf, ufs, vxfs, xfs, xiafs 等文件系统),如

果探测失败,就将访问/etc/filesystems ,以指定文件系统探测。说

明:如果清楚文件系统,更好指定具体类型。探测错误将带来灾难性

的。

多个文件系统可以用“,”分割开来.

-t vfstype mount -a -t nomsdos,ext

将挂载fstab文件指定所有的文件系统,除了类型为 msdos 和 ext 的

那一些。

1. 将 /usr 里的所有文件 完全 复制到 空分区中。历族注意软硬链接文件的问题。 可使用 cp -a 命令。 如果新分区够大,建议 采取压缩再释放的方法。cd /usr ; tar cvf (/新分区挂在目录/usr.tar) . ;cd /新分区挂在目录 ;tar xvf usr.tar -C .

2.安全起见,不要删除原来的 /usr 目录,建议改名,比如usr_ ,新建 /usr 文件夹

3.修改 /etc/fstab 文件,新建返敬 挂载规则,/usr 新分区 ……….(详细的可参考 fstab 的帮漏烂慎助文件)

还有一个偏门方法:

使用 aufs 或者 unionfs 绑定一个新的分区。这样新的文件就自动被转到新分区上建立。旧文件还在原来的分区上。

但玩这个需要一定的技术。如果楼主有闲心,可以试试。

我建议转换分区的时候。直旅铅接用 mv 把 /usr 的老文件转移到新的分区上。转移的时候可以先把新的 usr 分区挂载到一个临时的目录上,比如 /mnt/temp 。

关于磁盘太大linux挂不上的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux系统如何应对磁盘过大无法挂载的问题 (磁盘太大linux挂不上)