当配备ECC内存的
Linux机器识别内存故障时,如何收到通知?我对可纠正和无法纠正的错误感兴趣.
>如果将消息写入dmesg / syslog,这已经很好了,但我很想知道要查找什么
>安装额外的守护进程(如硬盘驱动器的smartmontools)是可以接受的
> Nagios / Icinga监控将是另一种方式
>并非所有要监控的计算机都具有IPMI
感兴趣的系统有Supermicro板(X9SCM-F),关于HP N54L微处理器,我只是好奇,但不要太在意.所有系统都运行Debian或Ubuntu Linux.
解决方法
Linux kernel supports一些芯片组的错误检测和纠正(
EDAC)功能.在支持的
ECC系统上,可以通过sysfs访问内存控制器的状态:
/sys/devices/system/edac/mc
该位置下的目录树应与您的硬件相对应,例如:
/sys/devices/system/edac/mc/mc0/csrow2/power /sys/devices/system/edac/mc/mc0/csrow0/power /sys/devices/system/edac/mc/mc0/dimm2/power /sys/devices/system/edac/mc/mc0/dimm0/power /sys/devices/system/edac/mc/mc1/power ...
根据您的硬件,您可能必须明确加载正确的edac驱动程序,参见:
find /lib/modules/$(uname -r) -name '*edac*'
edac-utils
package提供了一个命令行前端和一个用于访问该数据的库,例如:
edac-util -rfull mc0:csrow0:mc#0memory#0:CE:0 mc0:csrow2:mc#0memory#2:CE:0 mc0:noinfo:all:UE:0 mc0:noinfo:all:CE:0 mc1:noinfo:all:UE:0 mc1:noinfo:all:CE:0
您可以设置某种定期调用eac-util的cron-job,并将结果提供给监控系统,然后您可以在其中配置一些通知.
除此之外,运行mcelog
通常是一个好主意.取决于系统,但不可纠正/可纠正的ECC错误也可能被报告为机器检查异常(MCE).我的意思是,即使由于温度较高而短暂的CPU节流也被报告为MCE.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。