Toda vez que descriptografo minha unidade luks, a partição não aparece:
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
quando executo o 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
Quero montar a partição md0_crypt1 sempre que inicializar. Mas sem executar o partprobe todas as vezes.
Perdi algo?
Responder1
É incomum particionar dispositivos LUKS/LVM e, como tal, isso não é coberto pela maioria das ferramentas padrão. Na verdade, manter partições ocultas em dispositivos Device Mapper é um recurso, já que máquinas virtuais que usam volumes lógicos como dispositivos de backup normalmente particionam essas partições, mas NÃO querem que suas partições apareçam no host.
Quero montar a partição md0_crypt1 sempre que inicializar. Mas sem executar o partprobe todas as vezes.
Você está praticamente preso a isso. E depois de inseri-lo em algum lugar no seu script de inicialização, você nem notará a diferença... (em outras palavras: automatize-o)
Faça um backup antes de tentar qualquer coisa abaixo deste ponto.
Faça isso também em um LiveCD onde nada está montado.
Opção 1)
Você pode remover completamente a tabela de partições supérfluas (deslocar todos os dados em 2048, ou seja, o deslocamento da primeira e única partição). Comando altamente perigoso dd
:
dd status=progress bs=1M if=/dev/mapper/md0_crypt1 of=/dev/mapper/md0_crypt
Nota: fazer um dd'ing assim deve garantir que os dados que ainda não foram lidos sejam sobrescritos, portanto, isso não funcionaria na outra direção.
Opção 2)
Converter a tabela de partição para LVM também pode ser viável (e não requer a realocação de nenhum dado), no entanto, o LVM prefere uma área de metadados maior atualmente e também gosta de zerar e limpar assinaturas. Portanto, você deve ter cuidado para evitá-los e garantir que o primeiro PE comece em 1M, não em 2M ou em outros padrões maiores.
[ 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 ]
Isso pode ser feito, mas não deve ser tentado sem um backup completo.