...我怎样才能知道?
假设我即将重启服务器。我想尽量减少停机时间,因此考虑将重启包装成一个别名,表示“等一下,伙计,你将在启动时执行 fsck”。
下一个问题.. 说“下次再做吧”的最好方式是什么?设置最后检查日期?
我知道 tune2fs 可以设置一堆参数,但我如何获取它们?
答案1
如果您所要做的只是避免 fsck,那么在 shutdown 中添加 -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。
答案2
使用tune2fs -l /path/to/device
:
- 如果“安装数量”大于“最大安装数量”,则使用
-c
更改最大值或-C
更改数量 - 如果“上次检查”的时间对于“检查间隔”来说不够近,请使用
-i
更改间隔或-T
更改上次检查的时间
答案3
另一个选择是,您可以通过更新 /etc/fstab 中的第 6 个字段手动使其在启动时跳过 fsck 检查:
/dev/sda2 / ext3 defaults,errors=remount-ro 0 1
这与大多数 fstab 中的类似,1 表示应该检查并且是根文件系统,2 表示应该检查但将与其他文件系统并行进行,0 表示跳过检查
无论文件系统如何,情况都是如此
答案4
我使用以下 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 ~ $