使用parted命令对齐分区,以获得最佳性能

简介:

在Linux系统上的大型存储阵列上创建分区(译者注:实际上是对从阵列上划分给系统的LUN分区,系统将每个LUN识别为一个磁盘),会遇到两大常见问题。第一个问题很容易,使用fdisk命令得到的错误信息已经提示了解决问题的办法:

  1. WARNING: The size of this disk is 8.0 TB (7970004230144 bytes).

  2. DOS partition table format can not be used on drives for volumes

  3. larger than (2199023255040 bytes) for 512-byte sectors. Use parted(1) and GUID

  4. partition table format (GPT).

译者注:磁盘大小是8TB。DOS分区表格式不能在超过2TB(512个字节的扇区)的卷上使用。请使用parted命令和GUID分区表格式(GPT)

答案是:使用parted命令。如果你的系统上没有parted,请安装它吧!

第二个问题是来自parted的警告:

  1. (parted) mklabel gpt

  2. (parted) mkpart primary 0 100%

  3. Warning: The resulting partition is not properly aligned for best performance.

  4. Ignore/Cancel?

译者注:生成的分区没有正确地对齐以实现最佳性能。忽略/取消?

不论你使用怎样的数字组合,这条错误信息都不断地出现。你尝试选择了忽略,但错误根本没被忽略。

网上有一些讨论这个问题的帖子,惠普官方帮助论坛上的一个帖子真正戳中了问题的核心。(译者注:文中提到的惠普论坛帖子现已无法访问)

下面是正确对齐分区的快速分步指南。它是那个惠普帖子的提炼总结,希望大家能快速上手。这个方法对大多数阵列行之有效(实际上它适用于我所见过的所有阵列);在惠普的帖子中还提到了更多可行的配置选项,我在这里只列出最常用的配置。

1.获得你阵列的alignment参数(记得要将sdb替换为系统内核看到的设备名称)

  1. # cat /sys/block/sdb/queue/optimal_io_size

  2. 1048576

  3. # cat /sys/block/sdb/queue/minimum_io_size

  4. 262144

  5. # cat /sys/block/sdb/alignment_offset

  6. 0

  7. # cat /sys/block/sdb/queue/physical_block_size

  8. 512

2.把optimal_io_size的值与alignment_offset的值相加,之后除以physical_block_size的值。在我的例子中是:(1048576 + 0) / 512 = 2048。

3.这个数值是分区起始的扇区。新的parted命令应该写成类似下面这样

  1. mkpart primary 2048s 100%

2048s中的字母s是很有意义的:它告诉parted,你的输入是2048扇区,而不是2048字节,也不是2048兆字节。

4.如果一切顺利,分区将会被成功创建并没有任何警告信息。然后你就可以检查分区是否对齐了(如有必要,请将下面命令中的1替换为合适的分区号)。

  1. (parted) align-check optimal 1                                            

  2. 1 aligned

正如我之前暗示的,会有一些特例,上面的做法对那些特例并不奏效:例如,如果optimal_io_size是0,需要遵循其他的一些规则







相关文章
|
关系型数据库 Unix Linux
fdisk、parted无损调整普通分区大小
我们讲的调整分区大小,都是要保证不损坏分区中数据为前提。 这里我们讲一下用fdisk、parted调整普通分区的方法。 切记:一般都只用于扩容分区,如果要缩减分区,特别是根目录,可能会出问题 而扩容分区时,要保证跟扩容分区相邻的分区是未分配的(或者可以先暂时删除的)
12070 2
|
存储 运维 NoSQL
数据系统分区设计 - 分区再平衡(rebalancing)
随业务井喷,DB出现变化: 查询负载增加,需更多CPU处理负载 数据规模增加,需更多磁盘和内存来存储 节点可能故障,需要其他节点接管失效节点
171 0
|
存储 程序员 编译器
C++内存分区模型
C++内存分区模型
154 0
C++内存分区模型
|
弹性计算
parted重新创建分区扩展分区大小
parted重新创建分区扩展分区大小
|
5G Linux
10.15 Linux fdisk创建分区(主分区、扩展分区和逻辑分区)过程详解
本节我们实际建立一个主分区,看看过程是什么样子的。命令如下:
1204 0
10.15 Linux fdisk创建分区(主分区、扩展分区和逻辑分区)过程详解
|
Windows
Parted 创建 GPT 分区
对于磁盘的分区表 MBR与GPT区别。MBR:MBR分区表(即主引导记录)大家都很熟悉,是过去我们使用windows时常用的。所支持的最大卷:2T,而且对分区有限制:最多4个主分区或3个主分区加一个扩展分区 GPT: GPT(即GUID分区表)。
5678 0