我有一台Linux服务器,当我想查看它的硬盘大小时,我使用这个命令:df -h
但事实上,我知道,我的服务器由一些硬盘组成,它的原始磁盘空间不止于此。
可能有RAID。
我的问题是:
我如何知道(识别)服务器中是否使用了 RAID 并查看原始硬盘大小?
答案1
Linux 系统上有四个可能的位置可以配置 RAID:
- 在硬件层面。换句话说,您的系统中有一个实际的物理 RAID 控制器。没有简单的 100% 可靠的方法可以从软件中检查这一点,但是
lspci
如果你有的话,运行应该会列出它(尽管我不是 100% 确定)如何它将被列出)。 - 在固件级别。这在服务器系统上很少见,因为它通常比在硬件级别的效率低,并且比在块层的灵活性低。大多数 Intel 和 AMD SATA 控制器中的“RAID”模式就是一个例子。对于如何检查这一点,我的建议绝对为零,因为我不惜一切代价避免使用它(性能通常充其量只是平庸,而且 Linux 对配置的支持基本上不存在)。
- 在块层中。这是使用 MD 或 LVM 完成的 RAID。检查非常简单。如果
/proc/mdstat
列出任何设备,则表明您的系统上配置了 MD RAID。如果lvs -a
列出任何设备,则您的系统上可能有基于 LVM 的 RAID(如果“属性”列显示以r
第一个位置开头的任何内容,则您至少有一个具有复制(RAID1 或 RAID10)或擦除编码的卷(RAID5 或 RAID6)没有简单的方法来检查条带卷)。 - 在文件系统中。如果您的文件系统使用 ZFS 或 BTRFS,则可能会出现这种情况。对于 ZFS,我不太确定如何检查正在使用的复制/条带化/奇偶校验。对于 BTRFS,运行
btrfs filesystem show
并查看是否有任何卷列出了多个设备(对于您在这里关心的内容,此类卷应像 RAID 一样对待)。
现在,至于弄清楚磁盘有多大,您是正确的,但df
不会显示您想要的信息。它仅显示每个已安装文件系统的使用情况,这与显示每个磁盘的大小不同。
如果可以直接访问底层设备(上面的情况3和4都是这样,情况1和2通常也是这样),可以通过blockdev --getsize64
在设备上运行直接查询磁盘的大小,打印出设备的确切可用大小(以千字节为单位)。
如果您无法直接访问底层设备(上述情况 1 和 2 都有可能),则必须通过您拥有的任何 RAID 控制器的配置工具来查看它们。
当然,计算硬盘大小的最可靠方法是忽略所有涉及的软件,打开机箱,查看硬盘本身。所有现代驱动器的标签上都列出了其容量。