Tom Newton Asked: 2009-06-19 12:37:21 +0800 CST2009-06-19 12:37:21 +0800 CST 2009-06-19 12:37:21 +0800 CST 当我重新启动时,我的系统会 fsck 吗? 772 ……我怎么知道? 假设我要重新启动服务器。我想最大程度地减少停机时间,因此考虑将 reboot 包装在一个别名中,上面写着“挂在好友上,你将在启动时遇到 fsck”。 下一个问题.. 说“让我们下次做”的最佳方式是什么?设置最后检查日期? 我知道 tune2fs 可以设置一堆参数,但我怎么得到它们呢? linux fsck 8 个回答 Voted Best Answer freiheit 2009-06-19T12:58:58+08:002009-06-19T12:58:58+08:00 如果您只想避免使用 fsck,则将 -f 选项添加到 shutdown 应该会有所帮助。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。 brian-brazil 2009-06-19T12:52:46+08:002009-06-19T12:52:46+08:00 使用tune2fs -l /path/to/device: 如果“Mount count”将大于“Maximum mount counts”,则使用-c更改最大值或-C更改计数 如果“上次检查”对于“检查间隔”来说不够新,请使用-i更改间隔或-T更改上次检查 Brendan 2009-06-19T19:30:29+08:002009-06-19T19:30:29+08:00 另一个选项是您可以通过更新 /etc/fstab 中的第 6 个字段手动使其在引导时跳过 fsck 检查: /dev/sda2 / ext3 defaults,errors=remount-ro 0 1 这类似于大多数 fstabs 将具有的 1 表示它应该被检查并且是根文件系统,2 表示它应该被检查但将与其他文件系统并行完成,0 表示跳过检查 无论文件系统如何,这也是如此 chris 2010-04-16T06:00:01+08:002010-04-16T06:00:01+08:00 如果您不想猜测 - 请执行以下操作: 触摸/快速启动 并且您一定会避免缓慢的检查(或更糟糕的是 - 如果检查失败并且重新启动停止,则完全失败) RivieraKid 2010-04-20T01:34:16+08:002010-04-20T01:34:16+08:00 我使用以下 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 ~ $ kmarsh 2009-07-09T10:30:08+08:002009-07-09T10:30:08+08:00 我经常在中午重启之前使用 tunefs 来重置启动计数和时间,以防止 fsck。启动时间的差异是惊人的。之后我将它们重置以允许下一次引导到 fsck。 xebeche 2009-10-25T12:16:37+08:002009-10-25T12:16:37+08:00 我想过如何更舒服地获取文件系统列表: 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一个中,也可以快速查看文件系统有多大。 请注意,在上面的代码中,将“下一次检查”的时间与(NOW + 120 秒)进行比较,假设您的系统再次启动需要一些时间。 高温高压 Avyd 2013-10-17T07:13:47+08:002013-10-17T07:13:47+08:00 这是一个检查文件系统是否有 fsck ( source ) 的脚本: 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
如果您只想避免使用 fsck,则将 -f 选项添加到 shutdown 应该会有所帮助。shutdown -F 强制 fsck。
tune2fs -l /dev/foo
会告诉你有趣的信息。这是提取所需内容的开始:
如果“下次检查之后”日期已过,则会出现 fsck。
如果文件系统状态不干净,就会出现 fsck。(如果系统在重新启动/关闭期间出现问题,阻止干净卸载,也可能发生这种情况)
如果挂载计数已达到最大挂载计数,则会出现 fsck。
使用
tune2fs -l /path/to/device
:-c
更改最大值或-C
更改计数-i
更改间隔或-T
更改上次检查另一个选项是您可以通过更新 /etc/fstab 中的第 6 个字段手动使其在引导时跳过 fsck 检查:
这类似于大多数 fstabs 将具有的 1 表示它应该被检查并且是根文件系统,2 表示它应该被检查但将与其他文件系统并行完成,0 表示跳过检查
无论文件系统如何,这也是如此
如果您不想猜测 - 请执行以下操作:
触摸/快速启动
并且您一定会避免缓慢的检查(或更糟糕的是 - 如果检查失败并且重新启动停止,则完全失败)
我使用以下 perl 脚本来检查下一次 fsck 何时发生:
我让它在我的 ~/.bashrc 中运行,所以我总是知道什么时候会检查我的文件系统,尽管我现在使用 ext4,它不会受到 fsck 时间延长的影响,但很高兴知道。
典型的输出类似于:
我经常在中午重启之前使用 tunefs 来重置启动计数和时间,以防止 fsck。启动时间的差异是惊人的。之后我将它们重置以允许下一次引导到 fsck。
我想过如何更舒服地获取文件系统列表:
我想它可以做得更优雅,但无论如何它就是这样。如果将其通过管道传输到
xargs -r df -h
一个中,也可以快速查看文件系统有多大。请注意,在上面的代码中,将“下一次检查”的时间与(NOW + 120 秒)进行比较,假设您的系统再次启动需要一些时间。
高温高压
这是一个检查文件系统是否有 fsck ( source ) 的脚本: