程序因 /etc/localtime 超时而挂起

程序因 /etc/localtime 超时而挂起

在我的服务器上,突然大多数程序停止工作(它们只是挂起)。例如午夜指挥官。当我用 strace 调试 mc 时,我看到它挂起stat("/etc/localtime")

当我尝试cat /etc/localtime它时,它无限期地挂起。有人可以帮忙吗?

以下是输出strace cat /etc/localtime

execve("/bin/cat", ["cat", "/etc/localtime"], [/* 29 vars */]) = 0
brk(0)                                  = 0x2530000
access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or directory)
mmap(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd02fe08000
access("/etc/ld.so.preload", R_OK)      = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY)      = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=21338, ...}) = 0
mmap(NULL, 21338, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7fd02fe02000
close(3)                                = 0
access("/etc/ld.so.nohwcap", F_OK)      = -1 ENOENT (No such file or directory)
open("/lib/x86_64-linux-gnu/libc.so.6", O_RDONLY) = 3
read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\300\357\1\0\0\0\0\0"..., 832) = 832
fstat(3, {st_mode=S_IFREG|0755, st_size=1595408, ...}) = 0
mmap(NULL, 3709016, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x7fd02f861000
mprotect(0x7fd02f9e1000, 2097152, PROT_NONE) = 0
mmap(0x7fd02fbe1000, 20480, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x180000) = 0x7fd02fbe1000
mmap(0x7fd02fbe6000, 18520, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x7fd02fbe6000
close(3)                                = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd02fe01000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd02fe00000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fd02fdff000
arch_prctl(ARCH_SET_FS, 0x7fd02fe00700) = 0
mprotect(0x7fd02fbe1000, 16384, PROT_READ) = 0
mprotect(0x60b000, 4096, PROT_READ)     = 0
mprotect(0x7fd02fe0a000, 4096, PROT_READ) = 0
munmap(0x7fd02fe02000, 21338)           = 0
brk(0)                                  = 0x2530000
brk(0x2551000)                          = 0x2551000
open("/usr/lib/locale/locale-archive", O_RDONLY) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=1534672, ...}) = 0
mmap(NULL, 1534672, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7fd02fc88000
close(3)                                = 0
fstat(1, {st_mode=S_IFCHR|0600, st_rdev=makedev(136, 0), ...}) = 0
open("/etc/localtime", O_RDONLY)        = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=1892, ...}) = 0
fadvise64(3, 0, 0, POSIX_FADV_SEQUENTIAL) = 0
read(3, "TZif2\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\4\0\0\0\4\0\0\0\0"..., 32768) = 1892
write(1, "TZif2\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\4\0\0\0\4\0\0\0\0"..., 1892

答案1

这看起来像是内存或磁盘损坏。检查您的系统日志(例如/var/log/kern.log)以查看是否提到任何磁盘损坏。

无论您是否看到磁盘损坏的迹象,都请运行内存检查。内存测试86+包含在许多诊断套件中,或者您可以下载可启动映像;它也默认安装在 Ubuntu 上(从启动菜单中选择它)。让它运行至少一次完整的运行——您可以将其放置过夜。如果发现错误,请立即更换损坏的 RAM 模块。

相关内容