本文介绍初始化云盘时,在CentOS 7系统mount
本地盘时出现命令卡住现象的问题描述、问题原因和解决方案。
问题描述
在CentOS 7系统使用ext4文件系统批量初始化本地盘时,使用mount
命令挂载本地盘时出现命令卡住的现象,然后使用ps
命令查看mount进程为D状态(睡眠状态)。
问题原因
该问题是由于Linux的2.6.37
及更高的内核版本(通过uname -r
查询)默认启用了lazy init功能导致。CentOS 7系统的内核版本是3.10
,因此默认启用了lazy init功能。
使用ext4文件系统首次执行mount
操作时需要初始化inode table。但是CentOS 7默认启用了lazy init功能,导致在初始化ext4文件系统时不会立刻去初始化文件系统的inode table,而是在mount
挂载云盘时才进行。同时在3.10内核中mount
时会有获取IO锁的操作,本地盘规格族由于容量较大,系统需要随机在云盘中写入数据,初始化需要的时间长,会出现mount
需要的IO锁被lazy init长时间占用的情况,因此导致mount
命令卡住。
在4.x版本内核中,对锁机制进行了优化,因此没有这个问题。
关于本地盘的更多信息,请参见本地盘。
解决方案
方案一:关闭lazy init功能
在云盘初始化时执行以下命令,关闭lazy init功能。
mkfs.ext4 -E lazy_itable_init=0,lazy_journal_init=0
此方案在数据盘容量较大时,初始化也比较耗费。例如32块ecs.d3s.16xlarge规格的本地盘全部初始化挂载完成约耗时4.5~5小时。
云盘初始化的更多信息,请参见初始化概述。
方案二:使用xfs初始化
CentOS 7系统默认使用ext4文件系统,建议您使用xfs文件系统对云盘初始化。云盘初始化的更多信息,请参见初始化概述。
xfs文件系统的初始化策略是按需分配,因此没有ext4文件系统全盘初始化的操作, 此方案对数据盘进行初始化时挂载速度较快。例如32块ecs.d3s.16xlarge规格的本地盘全部初始化挂载完成仅需几分钟。
CentOS 7系统默认使用ext4文件系统,建议您在环境上使用xfs文件系统时进行测试验证后再进行业务操作,避免出现兼容性问题。