diskutil是macOS内置命令行磁盘管理工具,支持查看磁盘信息、格式化分区、验证修复文件系统、修复底层结构及安全擦除,适用于恢复模式、远程终端和自动化脚本。

如果您在 macOS 中需要对磁盘执行底层管理操作,例如格式化分区、验证或修复文件系统结构,但图形界面的“磁盘工具”受限或不可用,则可使用系统内置的 diskutil 命令行工具。该工具支持直接操作物理磁盘、APFS 容器、宗卷及传统 HFS+ 卷,适用于恢复模式、远程终端及自动化脚本场景。以下是具体操作方法:
一、查看磁盘与分区信息
该步骤用于识别目标设备标识符(如 disk0、disk2s1),是后续所有操作的前提。未正确识别设备可能导致误操作和数据丢失。
1、打开“终端”应用(可在“应用程序 > 实用工具”中找到)。
2、输入命令:diskutil list,按回车执行,列出全部连接的物理磁盘及其分区结构。
3、如需查看某磁盘详细属性(如文件系统类型、是否可写、挂载点),输入:diskutil info /dev/diskX(将 X 替换为实际数字,例如 disk1)。
4、若需仅显示已挂载宗卷及其路径,运行:diskutil apfs list(专用于 APFS 容器与宗卷关系展示)。
二、格式化分区(抹掉并重新创建文件系统)
此方法直接重建宗卷结构,会彻底清除指定目标上的全部数据。操作前必须确认设备路径无误,并已备份关键内容。
1、对非启动磁盘的 APFS 宗卷执行快速格式化:输入 diskutil eraseVolume APFS "新名称" /dev/diskXsY(其中 X 为磁盘编号,Y 为分区编号,例如 disk2s1)。
2、格式化为加密 APFS 宗卷:运行 diskutil apfs encryptVolume /dev/diskXsY -passphrase "您的密码",执行后需输入两次密码并等待加密完成。
3、格式化为 Mac OS 扩展(Journaled):使用命令 diskutil eraseVolume "Mac OS Extended (Journaled)" "名称" /dev/diskXsY。
4、全新初始化整块磁盘(含分区表):输入 diskutil partitionDisk /dev/diskX 1 GPT APFS "名称" 100%(将覆盖整个磁盘并建立单一分区)。
三、验证与修复宗卷文件系统
该操作检查宗卷元数据一致性(如目录节点、B-Tree 结构、权限标记等),并尝试自动修正逻辑错误,不涉及物理坏道检测。
1、仅验证 APFS 宗卷完整性(不修改):执行 diskutil verifyVolume /dev/diskXsY。
2、验证并自动修复 APFS 宗卷:运行 diskutil repairVolume /dev/diskXsY。
3、对 HFS+ 卷执行修复:使用命令 diskutil repairVolume /dev/diskXsY(同样适用,但内部调用 fsck_hfs)。
4、若修复失败且提示“卷无法卸载”,先强制卸载:diskutil unmountDisk force /dev/diskX,再重试 repairVolume。
四、修复底层磁盘结构(容器/物理设备)
当 APFS 容器损坏(如容器大小异常、宗卷无法挂载)、或磁盘出现分区表错误时,需作用于更高层级设备,而非单个宗卷。
1、验证 APFS 容器完整性:输入 diskutil verifyVolume /dev/diskX(注意此处为 diskX,非 diskXsY)。
2、修复 APFS 容器结构:运行 diskutil repairVolume /dev/diskX。
3、修复整个磁盘的分区表(GPT):使用 diskutil repairDisk /dev/diskX,该命令可重建主/备份 GPT 头和分区条目。
4、若磁盘被识别为“未知”或“未初始化”,尝试重置其可读状态:diskutil resetFusion(仅限 Fusion Drive)或 diskutil reclaimVolume /dev/diskXsY(用于回收 APFS 宗卷空间)。
五、卸载与安全擦除磁盘
在执行高危操作(如重新分区、销毁加密卷)前,必须确保目标设备已卸载;安全擦除则用于彻底清除敏感数据,防止恢复。
1、安全卸载单一分区:diskutil unmount /dev/diskXsY。
2、强制卸载整块磁盘(含所有分区):diskutil unmountDisk force /dev/diskX。
3、对 SSD 执行单次零填充擦除(不可逆):diskutil secureErase 0 /dev/diskX。
4、对机械硬盘执行七次 DoD 5220.22-M 标准擦除:diskutil secureErase 2 /dev/diskX(耗时极长,仅限必要场景)。









