Luks の復号化後にパーティションが表示されない

Luks の復号化後にパーティションが表示されない

luks ドライブを復号化するたびに、パーティションが表示されません。

cryptsetup -v luksOpen /dev/md0 md0_crypt

lsblk
sdb                             8:16   0   3,7T  0 disk  
└─sdb1                          8:17   0   3,7T  0 part  
  └─md0                         9:0    0   7,3T  0 raid5 
    └─md0_crypt               253:11   0   7,3T  0 crypt 
sdc                             8:32   0   3,7T  0 disk  
└─sdc1                          8:33   0   3,7T  0 part  
  └─md0                         9:0    0   7,3T  0 raid5 
    └─md0_crypt               253:11   0   7,3T  0 crypt 
sdd                             8:48   0   3,7T  0 disk  
└─sdd1                          8:49   0   3,7T  0 part  
  └─md0                         9:0    0   7,3T  0 raid5 
    └─md0_crypt               253:11   0   7,3T  0 crypt 

partprobeを実行すると

partprobe
lsblk
sdb                                 8:16   0   3,7T  0 disk  
└─sdb1                              8:17   0   3,7T  0 part  
  └─md0                             9:0    0   7,3T  0 raid5 
    └─md0_crypt                   253:11   0   7,3T  0 crypt 
      └─md0_crypt1                253:12   0   7,3T  0 part  
sdc                                 8:32   0   3,7T  0 disk  
└─sdc1                              8:33   0   3,7T  0 part  
  └─md0                             9:0    0   7,3T  0 raid5 
    └─md0_crypt                   253:11   0   7,3T  0 crypt 
      └─md0_crypt1                253:12   0   7,3T  0 part  
sdd                                 8:48   0   3,7T  0 disk  
└─sdd1                              8:49   0   3,7T  0 part  
  └─md0                             9:0    0   7,3T  0 raid5 
    └─md0_crypt                   253:11   0   7,3T  0 crypt 
      └─md0_crypt1                253:12   0   7,3T  0 part

fdisk:

Disk /dev/mapper/md0_crypt: 7,3 TiB, 8001299677184 bytes, 15627538432 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 524288 bytes / 1048576 bytes
Disklabel type: gpt
Disk identifier: A599A15F-07DA-B340-ADDC-AA56AE2E9249

Device                      Start         End     Sectors  Size Type
/dev/mapper/md0_crypt-part1  2048 15627536383 15627534336  7,3T Linux

起動するたびに md0_crypt1 パーティションをマウントしたいのですが、毎回 partprobe を実行せずに済みます。

私は何か見落としてますか?

答え1

LUKS/LVM デバイスをパーティション分割することは珍しいことであり、そのため、ほとんどの標準ツールでは対応していません。実際、デバイス マッパー デバイスでパーティションを非表示にしておくことは機能の 1 つです。これは、論理ボリュームをバッキング デバイスとして使用する仮想マシンは通常、それらのパーティションを分割しますが、そのパーティションがホスト上に表示されないようにするためです。

起動するたびに md0_crypt1 パーティションをマウントしたいのですが、毎回 partprobe を実行せずに済みます。

ほとんどそのままです。そして、それをどこかの init スクリプトに組み込めば、違いに気付くことさえないでしょう... (言い換えれば、自動化するということです)


このポイントより下のものを試す前にバックアップを作成してください。
何もマウントされていない LiveCD からもこれを実行してください。

オプション1)

余分なパーティション テーブルを完全に削除できます (すべてのデータを 2048 ずつシフトします。つまり、最初のパーティションのオフセットです)。非常に危険なddコマンド:

dd status=progress bs=1M if=/dev/mapper/md0_crypt1 of=/dev/mapper/md0_crypt

注意: このように dd を実行する場合は、まだ読み取られていないデータを上書きしないようにする必要があります。そのため、逆方向では機能しません。

オプション2)

パーティション テーブルを LVM に変換することも可能かもしれませんが (データの再配置は必要ありません)、LVM は最近、より大きなメタデータ領域を好み、署名をゼロにして消去する傾向があります。そのため、これらを回避するように注意し、最初の PE が 2M やその他のより大きなデフォルトではなく 1M から始まるようにする必要があります。

[ replace /dev/loop0 with /dev/mapper/md0_crypt ]
# vgcreate --dataalignment 1M --metadatasize 128K vgname /dev/loop0
[ this step will wipe GPT signature ]
# pvs -o +pe_start /dev/loop0
  PV         VG     Fmt  Attr PSize    PFree 1st PE 
  /dev/loop0 foobar lvm2 a--  1020.00m    0    1.00m
                                             ^^^^^^^
[ 1st PE must be 1.00m (2048s) otherwise abort mission! ]
# lvcreate --wipesignatures n --zero n -l100%FREE -n lvname vgname
# file -sL /dev/vgname/lvname
/dev/vgname/lvname: Linux rev 1.0 ext4 filesystem data [...]
[ if there's no filesystem, something went wrong ]

実行は可能ですが、完全なバックアップなしで実行しないでください。

関連情報