実験の目的で、単一のシステムにできるだけ多くのディスクをマウントする必要があります。スペアディスクが6つしかなかったので、これを128のGPTパーティションに分割し、各パーティションを使用してデバイスのRAID0アレイを作成することにしました。
問題は、mdadmが512個の配列のみを生成/dev/md[0-511]
し、他の配列を生成できないことです。
513番目のアレイを作成しようとした後、エラーが発生します。
% mdadm -C /dev/md512 -l raid0 -n 1 /dev/sdd128 --force
mdadm: /dev/md512 を開くときに予期しないエラーが発生しました。
これがデザインの限界ですか?バイパスする方法はありますか?
答え1
/dev/md*
単一のLinuxシステムの最大アレイ制限に達しました。
これは、従来のUnixデバイスのメジャー番号とマイナー番号に関連しています。最初に、MD RAIDドライバはプライマリブロックデバイス番号9(/usr/include/linux/raid/md_u.h
MD_MAJORと定義されています)を割り当て、256個のサブデバイス番号セットを許可し、256個の一意のRAIDアレイデバイスを許可します。(デバイス番号割り当ての標準的なリストは、カーネルソースパッケージに付属のドキュメントに含まれています。)
mdp_major
これは最終的に不十分であることが判明し、256を超えるRAIDアレイが必要な場合に追加のメジャー番号(カーネルコードから呼び出される)を使用するメカニズムが開発されました。カーネルソースファイルでそれを処理するコードを見つけることができます.../drivers/md/md.c
。追加のキー番号は、ダイナミックmdp_major
キー番号の範囲(234..254、上から始めて下へ)で動的に割り当てられます。
単一ホストで512を超えるMD RAIDアレイを使用するには、必要に応じて複数の動的プライマリ番号を使用するようにこのメカニズムを再構築する必要があります。
答え2
やや汚れた解決策があります(3.10.0-862.11.6
ブランチの最新のカーネルで動作します)。
# echo md512 > /sys/module/md_mod/paramaters/new_array
# mdadm -C /dev/md512 -l raid0 -n 1 /dev/sdd128 --force