0

0

Linux磁盘基础结构理解_分区与文件系统解析【教程】

舞夢輝影

舞夢輝影

发布时间:2025-12-31 14:58:02

|

321人浏览过

|

来源于php中文网

原创

现代Linux用/dev/sda而非/dev/hda因内核SCSI子系统抽象覆盖SATA/NVMe/USB等,而hda属已弃用IDE驱动;fdisk默认MBR、parted默认GPT;ext4兼容性好,xfs适合大文件高并发;df容量不准常因reserved blocks或quota挂载选项。

linux磁盘基础结构理解_分区与文件系统解析【教程】

磁盘设备名为什么/dev/sda 而不是 /dev/hda

现代 Linux 系统中,/dev/sda 这类命名来自内核的 SCSI 子系统抽象,它不只用于物理 SCSI 硬盘,也覆盖 SATA、NVMe(通过 nvmfnvme 驱动模拟)、USB 存储等——只要走的是内核的 sd(SCSI disk)驱动层,就统一叫 sdasdb……
而旧式 /dev/hda 属于已弃用的 IDE 驱动(ide subsystem),在 2.6 内核后期就被逐步移除;当前主流发行版(如 Ubuntu 20.04+、RHEL 8+)默认不加载 ide 模块,hda 几乎不会出现。
验证方式:

ls /sys/block/ | grep -E '^(sd|nvme|vd)'
——看到的都是 sdXnvme0n1 或云环境下的 vdX

fdiskparted 划分分区时的关键区别

二者底层都操作分区表,但语义和默认行为差异明显:

  • fdisk 默认使用 DOS MBR 分区表(最大支持 2TB + 4 个主分区),交互式操作,对 GPT 支持较弱(需手动切模式)
  • parted 默认识别并优先使用 GPT(尤其在磁盘 >2TB 时自动启用),命令式语法更直接,且原生支持对齐检查(unit MiB + align-check optimal 1
  • 误操作风险点:用 fdisk 对已有 GPT 磁盘执行 w,可能静默覆盖 GPT 头部为 MBR,导致分区“消失”(实际数据未删,但系统无法识别)
建议:新磁盘一律用 parted,先运行
parted /dev/sdb print
确认当前分区表类型;若要强制初始化为 GPT,用
parted /dev/sdb mklabel gpt
而非 fdisko 命令。

格式化时选 mkfs.ext4 还是 mkfs.xfs

选择取决于 I/O 模式与运维习惯,不是性能绝对高低:

HIX.AI
HIX.AI

HIX.AI是一个多功能的一体化AI写作助手,集成了120多种AI写作工具,支持50多种语言,能够满足各种写作需求。

下载
  • ext4 兼容性最好,tune2fs 可精细调参(如禁用 journal 降低写放大),适合中小文件多、需要 e2fsck 修复能力的场景
  • xfs 在大文件连续读写、高并发元数据操作(如大量小文件创建/删除)下更稳,但不支持 shrink(缩小文件系统),且 xfs_repair 要求文件系统处于 unmounted 状态,恢复窗口更长
  • 注意:两者默认 block size 均为 4K,但 xfs 的 inode size(-i size=512)和 ext4-i(bytes per inode)计算逻辑不同,盲目套用会导致 inode 耗尽或浪费
实操建议:Web 日志盘、数据库 WAL 目录优先 xfs;系统根分区、备份归档盘用 ext4;格式化前务必确认目标设备,例如
mkfs.xfs -f /dev/sdb1
中的 -f 会跳过确认,手抖输错设备将直接覆写。

挂载后 df -h 显示容量不准?检查 reserved blocks 和挂载选项

df 显示的 “Available” 不等于 “Size − Used”,因为 ext 类文件系统默认保留 5% 的空间给 root 用户(防止单用户下系统完全写满崩溃),这部分计入 Used 但不计入普通用户可用空间。
查看保留比例:

tune2fs -l /dev/sdb1 | grep "Reserved block count"

调整(例如改为 1%):
tune2fs -m 1 /dev/sdb1

另一个常见原因是挂载时用了 noatimerelatime,这本身不影响容量计算,但若同时启用了 user_xattracl,某些旧版工具(如早期 ncdu)可能因无法读取扩展属性而少算部分元数据占用。
真正影响 df 结果的挂载选项只有:bind(显示源路径统计)、overlay(叠加层逻辑)、以及 quota(配额启用后 df 显示配额限制而非真实剩余)。

相关专题

更多
数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

330

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2068

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

402

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

368

2023.10.16

vb连接数据库的方法
vb连接数据库的方法

vb连接数据库的方法有使用ADO对象库、使用OLEDB数据提供程序、使用ODBC数据源等。详细介绍:1、使用ADO对象库方法,ADO是一种用于访问数据库的COM组件,可以通过ADO连接数据库并执行SQL语句。可以使用ADODB.Connection对象来建立与数据库的连接,然后使用ADODB.Recordset对象来执行查询和操作数据;2、使用OLEDB数据提供程序方法等等。

217

2023.10.19

小游戏4399大全
小游戏4399大全

4399小游戏免费秒玩大全来了!无需下载、即点即玩,涵盖动作、冒险、益智、射击、体育、双人等全品类热门小游戏。经典如《黄金矿工》《森林冰火人》《狂扁小朋友》一应俱全,每日更新最新H5游戏,支持电脑与手机跨端畅玩。访问4399小游戏中心,重温童年回忆,畅享轻松娱乐时光!官方入口安全绿色,无插件、无广告干扰,打开即玩,快乐秒达!

30

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号