... и как мне узнать?
Скажем, я собираюсь перезагрузить сервер. Я хотел бы свести к минимуму время простоя, поэтому подумайте о том, чтобы обернуть перезагрузку псевдонимом, который гласит: «Держись, дружище, при загрузке вы получите fsck».
Следующий вопрос ... как лучше всего сказать "давай сделаем это в следующий раз?" установить дату последней проверки?
Я знаю, что tune2fs может устанавливать кучу параметров, но как мне их получить?
Если все, что вы хотите сделать, это избежать fsck, добавление опции -f в shutdown должно помочь в этом. выключение -F, чтобы заставить fsck.
tune2fs -l /dev/foo
расскажу интересную информацию.
Вот и начало извлечения того, что вам нужно:
mount -l -t ext3,ext2 | cut -d' ' -f1 | xargs -n1 tune2fs -l | egrep -i 'state|mount|check'
Если дата «Следующая проверка после» уже прошла, появится сообщение fsck.
Если состояние файловой системы не чистое, будет fsck. (это также может произойти, если во время перезагрузки / выключения возникла проблема с системой, которая препятствует чистому отключению)
Если количество монтирований достигло максимального количества монтирований, будет fsck.
С помощью tune2fs -l /path/to/device
:
-c
изменить макс или -C
изменить счет-i
изменить интервал или -T
изменить последний проверенныйдругой вариант - вы можете вручную пропустить проверки fsck при загрузке, обновив 6-е поле в вашем / etc / fstab:
/dev/sda2 / ext3 defaults,errors=remount-ro 0 1
Это похоже на то, что у большинства fstabs будет 1 означает, что он должен быть проверен и является корневой файловой системой, 2 означает, что он должен быть проверен, но будет выполняться параллельно с другими файловыми системами, а 0 означает пропустить проверку
это также верно независимо от файловой системы
Если не хотите гадать - сделайте так:
тач / фастбут
и вы наверняка избежите медленных проверок (или, что еще хуже, полного отказа, если проверка завершится неудачно и перезагрузка остановится)
Я использую следующий сценарий perl, чтобы проверить, когда произойдет следующий fsck:
#!/usr/bin/perl -w
use strict;
my $mountcount = 0;
my $maxmount = 0;
my $dev;
my $mountpoint;
my $fstype;
my $debug = 0;
my $cmd = "mount";
open MOUNT, sprintf ( "%s |", $cmd ) or die sprintf ( "ERROR: Cannot execute %s - %s\n", $cmd, $! );
while ( <MOUNT> ) {
chomp;
( $dev, undef, $mountpoint, undef, $fstype, undef ) = split;
printf "Found device %s\n", $dev if ( $debug > 0 );
if ( $fstype =~ /^ext/i ) {
$cmd = sprintf "dumpe2fs -h %s 2>&1", $dev;
open DUMPE2FS, sprintf ( "%s |", $cmd ) or die sprintf ( "ERROR: Unable to execute %s - %s\n", $cmd, $! );
while ( <DUMPE2FS> ) {
chomp;
if ( /^Mount count:/ ) {
( undef, $mountcount ) = split /:/;
$mountcount =~ s/\s*//g;
printf "Mount count = %s\n", $mountcount if ( $debug > 0 );
}
if ( /^Maximum mount count:/ ) {
( undef, $maxmount ) = split /:/;
$maxmount =~ s/\s*//g;
printf "Maximum mount count = %s\n", $maxmount if ( $debug > 0 );
}
}
close DUMPE2FS;
printf "Filesystem %s, mounted on %s will be checked in %s mounts\n", $dev, $mountpoint, $maxmount - $mountcount;
}
}
close MOUNT;
У меня он запускается в моем ~ / .bashrc, поэтому я всегда знаю, когда мои файловые системы будут проверены, хотя сейчас я использую ext4, который не страдает от увеличенного времени fsck, все же приятно знать.
Типичный вывод выглядит примерно так:
Filesystem /dev/sda1, mounted on / will be checked in 5 mounts
user@localhost ~ $
Я регулярно использую tunefs для сброса счетчика загрузки и времени перед перезагрузкой в середине дня, чтобы предотвратить появление fsck. Разница во времени загрузки потрясающая. Послесловия я сбросил их, чтобы разрешить следующую загрузку на fsck.
Я подумал, как удобнее получить список файловых систем:
for D in $(mount -l -t ext3,ext2 | cut -d' ' -f1 ) ; do \
echo --- $D; tune2fs -l $D | egrep -i 'mount (count|time)|check' ; done \
| awk '
/^--- / { mydev=$2; checked=0 }
/^Mount count:/ { mycnt=$3 }
/^Maximum mount count:/ { if (mycnt >= $3) checked=1 }
/^Next check after:/ {
cmd=("date +%s -d\"" $4 FS $5 FS $6 FS $7 FS $8"\"");
cmd | getline mydate; close(cmd);
if ((mydate <= (systime()+120)) || (checked == 1)) print mydev;
}
'
Думаю, это можно было бы сделать изящнее, но все равно вот оно. Если ввести это в xargs -r df -h
можно также быстро увидеть, насколько велики файловые системы.
Обратите внимание, что в приведенном выше коде время «следующей проверки» сравнивается с (ТЕПЕРЬ + 120 секунд), предполагая, что потребуется некоторое время, пока ваша система снова не заработает.
HTH
Вот скрипт, который проверяет ваши файловые системы на наличие fsck (источник):
for x in $(df -t ext4 -t ext3 -t ext2 | tr -s ' ' | cut -d " " -f1 | grep -v "^$" | tail -n +2); do mmc=$(tune2fs -l $x | grep 'mount count' | tr -s ' ' | cut -d ' ' -f4) ; mc=$(tune2fs -l $x | grep 'Mount count' | tr -s ' ' | cut -d ' ' -f3) ; if [ `expr $mmc - $mc` -le 0 ] ; then fsck="0" ; else fsck="1"; fi ; CT=`date +%s` ; LCT=`date -d "\`tune2fs -l $x | grep "Last checked" | tr -s ' '| cut -d" " -f3-\`" +%s` ; CI=`tune2fs -l $x | grep "Check interval"| tr -s ' '| cut -d" " -f3` ; if [ `let $CT-$LCT` -gt `let $CI*3600*24` ] && [ $CI -gt 0 ] || [ $fsck -eq 1 ]; then echo "There will be forced fsck for $x"; else echo "There will be no fsck for $x" ; fi ; done
# Alternative script from friend with sed
# mount -t ext2,ext3,ext4|while read i j; do tune2fs -l $i|sed -n '/[Mm]ount count/{s/.*: *//;p}'|(read c; read m; [ $m -gt 0 -a $m -le $c ] && echofsck,count,$i); c="$(tune2fs -l $i|sed -n '/Next check/{s/.*r: *//;p}')"; [ -z "$c" ] || ([ `date +%s` -ge `date -d"$c" +%s` ] && echo fsck,time,$i); done