O que devo fazer para forçar a verificação do sistema de arquivos raiz (e, opcionalmente, uma correção) na inicialização?

10

Ontem, um de nossos computadores caiu para o grubshell ou, honestamente, não tenho certeza de qual era o shell quando ligamos a máquina.

Ele mostrou que não pode montar o sistema de arquivos raiz ou algo nesse sentido, devido a inconsistências.

Eu corri, acredito:

fsck -fy /dev/sda2

Reiniciou e o problema se foi.

Aqui vem a parte da pergunta:

Eu já tenho no crontab de sua raiz:

@reboot /home/ruzena/Development/bash/fs-check.sh

enquanto o script contém:

#!/bin/bash
touch /forcefsck

Pensando nisso, não sei, por que criei um arquivo de script para um comando tão curto, mas de qualquer maneira ...

Além disso, no arquivo:

/etc/default/rcS

Eu defini:

FSCKFIX=yes

Então eu não entendo. Como a situação poderia surgir?


O que devo fazer para forçar a verificação do sistema de arquivos raiz (e, opcionalmente, uma correção) na inicialização?

Ou essas duas coisas são o máximo que posso fazer?

SO: Linux Mint 18.x Cinnamon de 64 bits.

fstab:

cat /etc/fstab | grep ext4

mostra:

UUID=a121371e-eb12-43a0-a5ae-11af58ad09f4    /    ext4    errors=remount-ro    0    1

grub:

fsck.mode=force

já foi adicionado à grubconfiguração.

LinuxSecurityFreak
fonte

Respostas:

12

ext4 verificação do sistema de arquivos durante a inicialização

Testado no SO: Linux Mint 18.x em uma máquina virtual

Informação básica

/etc/fstabtem o fsckpedido como a última (6a) coluna, por exemplo:

<file system>    <mount point>    <type>    <options>    <dump>    <fsck>
UUID=2fbcf5e7-1234-abcd-88e8-a72d15580c99 / ext4 errors=remount-ro 0 1

FSCKFIX=yes variável em /etc/default/rcS

Isso mudará o fsck para correção automática, mas não forçará uma verificação do fsck.

De man rcS:

FSCKFIX
    When  the  root  and all other file systems are checked, fsck is
    invoked with the -a option which means "autorepair".   If  there
    are  major  inconsistencies then the fsck process will bail out.
    The system will print a  message  asking  the  administrator  to
    repair  the  file  system manually and will present a root shell
    prompt (actually a sulogin prompt) on the console.  Setting this
    option  to  yes  causes  the fsck commands to be run with the -y
    option instead of the -a option.  This will tell fsck always  to
    repair the file systems without asking for permission.

De man tune2fs

If you are using journaling on your filesystem, your filesystem
will never be marked dirty, so it will not normally be checked.

Começar com

Definir o seguinte

FSCKFIX=yes

no arquivo

/etc/default/rcS

Verifique e observe a última vez que fs foi verificado:

sudo tune2fs -l /dev/sda1 | grep "Last checked"

Essas duas opções NÃO funcionaram

  1. Passando o argumento -F(forçar fsckna reinicialização) para shutdown:

    shutdown -rF now
    

    Não; veja: man shutdown.

  2. Adicionando o /forcefsckarquivo vazio com:

    touch /forcefsck
    

    Esses scripts parecem usar isso:

    /etc/init.d/checkfs.sh
    /etc/init.d/checkroot.sh
    

    se não trabalhar na reinicialização, mas o arquivo foi excluído.

    Verificado por:

    sudo tune2fs -l /dev/sda1 | grep "Last checked"
    sudo less /var/log/fsck/checkfs
    sudo less /var/log/fsck/checkroot
    

    Esses parecem ser os logs dos initscripts.

Repito, essas duas opções NÃO funcionaram!


Ambos os métodos funcionaram

  1. comutadores de inicialização do kernel systemd-fsck

    Editando o grubarquivo de configuração principal :

    sudoedit /etc/default/grub
    
    GRUB_CMDLINE_LINUX="fsck.mode=force"
    
    sudo update-grub
    sudo reboot
    

    Isso fez uma verificação do sistema de arquivos conforme verificado com:

    sudo tune2fs -l /dev/sda1 | grep "Last checked"
    

    Nota: Isso fez uma verificação, mas para forçar uma correção também, você precisa especificar fsck.repair="preen", ou fsck.repair="yes".

  2. Usando tune2fspara definir o número de montagens do sistema de arquivos antes de fazer um fsck,man tune2fs

    tune2fs' info is kept in the file system superblock
    

    -c switch define o número de vezes para montar o fs antes de verificar o fs.

    sudo tune2fs -c 1 /dev/sda1
    

    Verifique com:

    sudo tune2fs -l /dev/sda1
    

    Este DID funcionou como verificado com:

    sudo tune2fs -l /dev/sda1 | grep "Last checked"
    

Sumário

Para forçar um fsckem cada inicialização no Linux Mint 18.x, use tune2fs, ou fsck.mode=force, com fsck.repair=preen/ opcional fsck.repair=yes, as opções de linha de comando do kernel.

jc__
fonte