Tenho uma situação (acho) muito particular no meu Linux embarcado que não consigo resolver corretamente...
Devido a verificações específicas (personalizadas) a serem executadas em sistemas de arquivos na inicialização antes de montá-los, eu uso um ramdisk inicial para verificar e montar todos os sistemas de arquivos solicitados e, então, os transfiro para o sistema de arquivos raiz quando o init é concluído (então nenhum /etc/fstab
dispositivo é usado para montar, mas eles são montados por meio de um script que reside dentro do ramdisk inicial).
Para ser mais específico, a /boot
partição ( mmcblk1p1
) é montada primeiro (no modo SOMENTE LEITURA); dentro dessa partição, tenho um arquivo ( rootfs.squashfs
) correspondente a uma imagem squashfs do sistema de arquivos raiz de destino... então, após algumas outras operações (não relevantes para o propósito deste post), o script ramdisk inicial acaba montando a imagem squashfs /rootfs
e, no final do script init, a raiz do sistema é alternada /rootfs
(via switch-root
comando);
O problema surge na reinicialização do sistema (ou desligamento): quando o sistema tenta desmontar todos os sistemas de arquivos montados, a desmontagem /boot
falha (porque o dispositivo está ocupado, como é óbvio, já que o sistema de arquivos raiz é montado a partir de um arquivo squashfs que reside em /boot).
Existe uma maneira de evitar desmontar /boot
na reinicialização/desligamento/desligamento, evitando assim a falha de umount? Como ele é montado somente para leitura, não deve ser arriscado, não é? Ou estou esquecendo de algo?
PS: Não sei se pode ser útil e/ou relevante: a inicialização do meu sistema operacional é gerenciada via systemd
.
Na verdade, você não precisa alterar a ordem. Como o sistema de arquivos é somente leitura, é seguro apenas dizer ao kernel que ele pode terminar a desmontagem mais tarde (quando não houver mais referências) em vez de exigir que ele tenha sucesso imediatamente.
Na
boot.mount
configuração da unidade, defina o sinalizadorLazyUnmount=true
.https://www.freedesktop.org/software/systemd/man/latest/systemd.mount.html#LazyUnmount=
(Se você nunca criou
.mount
arquivos de unidade manualmente, eles são criados por um gerador systemd que verifica o fstab; você ainda pode substituir unidades de montagem por arquivos drop-in, mesmo que não os crie você mesmo).O Systemd suporta um recurso 'exitrd' (também conhecido como 'shutdown initramfs'), onde durante o desligamento tardio ele retornará para um sistema de arquivos RAM e executará o script fornecido, que pode então desmontar o sistema de arquivos raiz "real" da maneira que desejar.
O exitrd será usado quando um
/run/initramfs/shutdown
executável for encontrado. Após o systemd ter parado todas as unidades e executado em seu manipulador de desligamento final, em vez de imprimir "Unable to finalize filesystems" ele irá switch_root para/run/initramfs
, colocar o sistema de arquivos raiz real em/oldroot
, e executar o/shutdown
script.