一起学习网 一起学习网


Linux mcheck:系统错误机制大揭密 (mcheck linux)

网络编程 Linux mcheck:系统错误机制大揭密 (mcheck linux) 10-09

概述:

在Linux操作系统中,mcheck是一个用于错误检查和处理的机制,其主要功能是在系统硬件和操作系统运行时出现错误时进行检查,并在必要时引发错误处理程序以避免系统崩溃和数据丢失。本文将深入探讨Linux mcheck的机制和实现,以及其在错误检查中的重要作用。

一、Linux mcheck的背景

在计算机系统中,错误或故障可能对整个系统造成不可逆的损害,导致系统崩溃、数据丢失等严重后果。为了解决这一问题,Linux操作系统引入了mcheck机制以检查和处理系统错误。mcheck是一个内核接口,主要用于硬件错误检查,并提供一个通用接口来注册错误处理程序。

二、Linux mcheck的功能

Linux mcheck主要负责以下功能:

1. 捕获硬件错误:mcheck可以监控系统硬件的状态,如CPU,内存控制器,总线和存储器,并在硬件错误发生时捕获错误信息。

2. 硬件错误检查:mcheck可以识别硬件错误的类型和位置,并检查是否有其他相关错误。

3. 硬件错误恢复:mcheck可以使用特定的错误处理程序来处理硬件错误以恢复系统状态。

4. 系统保护:mcheck可以用来保护系统免受硬件错误的破坏,有助于提高系统的稳定性和可靠性。

三、Linux mcheck的实现

Linux mcheck的实现基于硬件平台的特定需求。在Intel x86平台上,mcheck是通过Machine Check Architecture(MCA)来实现的。MCA是一个计算机硬件架构,其主要目的是在系统出现预定义的硬件或软件错误时提供错误报告和恢复支持。MCA硬件架构在现代Intel处理器和芯片组中得到了广泛的应用。

MCA框架包括两种错误类型:CPU或本地总线错误和总线或I/O相互作用错误。CPU或本地总线错误包括CPU内部错误、缓存错误、总线错误、总线事务错误、机器检查异常等。总线或I/O相互作用错误包括外设错误、DMA错误、PCI错误等。当系统出现这些类型的错误时,MCA将自动发送错误报告到操作系统,启动错误处理程序以处理错误。

在Linux中,mcheck驱动程序可用于检测并处理MCA错误。驱动程序扫描处理器错误状态寄存器,从硬件检测到的错误信息构造错误报告,并调用错误处理程序以处理错误。

四、Linux mcheck的实际应用

Linux mcheck已被广泛应用于服务器系统中,如数据中心、云计算、虚拟化和大型企业网络等领域。在这些环境中,系统可用性和数据完整性是至关重要的。通过使用mcheck机制来检测和处理错误,可以避免硬件或系统故障对业务造成的损失,提高系统可靠性和稳定性,确保业务高效运行。

五、

Linux mcheck是一个重要的错误检查和处理机制,可以有效地检测和处理硬件错误,提高系统的可靠性和稳定性。本文介绍了Linux mcheck的机制和实现,以及其在错误检查中的重要作用。Linux mcheck已被广泛应用于数据中心、云计算、虚拟化和大型企业网络等领域,为业务稳定运行提供了可靠的保障。

相关问题拓展阅读:

  • 如何在linux下检测内存泄漏
  • linux下C语言的库函数的头文件放在哪个目录下啊?
  • 如何使用modprobe命令来加载,卸载和查看模块

如何在linux下检测内存泄漏

检测内存泄露主要有以下5种方法:1、在需要内存泄漏检查的代码的开始调用void mtrace(void) (该函数在头文件mcheck.h中有声明)。mtrace为malloc等函数安装hook,用于记录内存分配信息.在需要内存泄漏检查的代码的结束调用void muntrace(void)。注意: 一般情况下不要调用muntrace, 而让程序自然结束. 因为可能有些释放内存代码要到muntrace之后才运行. 2、用debug模式编译被检查代码(-g或-ggdb)。3、设置环境变量MALLOC_TRACE为一文件名, 这一文件将存有内存分配信息。 4、运行被检查程序, 直至结束或muntrace被调用。5、用mtrace命令解析内存分配Log文件($MALLOC_TRACE) (mtrace foo $MALLOC_TRACE, where foo is the executible name) 如果有内存泄漏,mtrace会输出分配泄漏 内存的代码位置,以及分配数量。

valgrind –track-fds=yes –leak-check=full –undef-value-errors=yes ./a.out

linux下C语言的库函数的头文件放在哪个目录下啊?

一般来说是棚谈放在/usr/include目录下圆和梁的;

    但是这个并不局限橘运也是可控的,如果我们进行开发过程中, 就会在内核的库函数文件目录:

例如在:/XXX/XXX/linux-X.X/include

    所以根据不同的情况,

头文件

存放的目录也是不同的,具体需要可以根据locate和grep命令进行查询。

在 /usr/include/下面

ls /usr/include/

FlexLexer.h ext2fs keyutils.hnetashsepol

GLfcntl.h krb netatalk setjmp.h

PCSCfeatures.hkrb5.h netaxsgtty.h

SDLfenv.h kudzu netdb.h shadow.h

Xfmtmsg.hlanginfo.hneteconet shhopt.h

_G_config.h fnmatch.hlastlog.hnetinet signal.h

a.out.hfontconfiglber.h netipxslang

aclform.h lber_types.hnetpacket slapi-plugin.h

af_vfs.h fpu_control.hldap.h netromsound

aio.hfreetypeldap_cdefs.hnetrose spawn.h

aliases.h fstab.h ldap_features.hnewt.hsqlite3.h

alloca.h ft2build.hldap_schema.hnfsss

alsafts.h ldap_utf8.hnl_types.h stab.h

ar.hftw.h libIDL-2.nlist.h startup-notification-1.0

argp.hfw_context.hliba2ps.hnsprstdint.h

argz.hgail-1. libart-2.nss.hstdio.h

arpagconf libbonobo-2.nssstdio_ext.h

agconv.h libbonoboui-2.nstring.h stdlib.h

a-generic gcrypt-module.hlibcroco-0.obstack.h string.h

assert.h gcrypt.hlibdevmapper-event.h oggstringprep.h

at-spi-1. gd.h libdevmapper.hopenssl strings.h

atk-1.gd_io.h libelf.horbit-2.0 stropts.h

attrgdbm libexsltpacker.h sys

audiofile.h gdbm.h libgen.hpam.hsyscall.h

aupvlist.h gdcache.hlibglade-2.pammap.h sysexits.h

baudboy.h gdfontg.hlibgnome-2.panel-2.0 syslog.h

bitio.hgdfontl.hlibgnomecanvas-2.0 panel.h tar.h

bitsgdfontmb.hlibgnomeprint-2.2 pango-1.0 tcpd.h

blkidgdfonts.hlibgnomeprintui-2.2 paths.h term.h

bonobo-activation-2.gdfontt.hlibgnomeui-2.pbm.htermcap.h

boostgdfx.h libgsf pbmfont.h termio.h

byteswap.h gelf.h libgswitchitpcitermios.h

bzlib.hgetopt.hlibgtop-2.pgm.htgmath.h

c++gif_lib.hlibgweatherpm.hthread_db.h

cairoglib-2. libintl.hpm_config.h tiff.h

cky_applet.h glob.h libio.h pm_gamma.h tiffconf-32.h

cky_base.h gmp-i386.hlibiscsi.hpm_system.h tiffconf.h

cky_card.h gmp-mparam-i386.h libmng.hpng.htiffio.h

cky_factory.h gmp-mparam.hlibmng_conf.hpngconf.h tiffio.hxx

cky_list.h gmp.h libmng_types.hpnm.htiffvers.h

colorname.h gmpxx.h libnotifypoll.htime.h

complex.h gnome-desktop-2.0 libpng popt.htld.h

cpio.hgnome-keyringlibrsvg ppm.httyent.h

crack.hgnome-python-2.libsoup-2.ppmcmap.h ttylock.h

crypt.hgnome-vfs-2.libuser ppmfloyd.h tux.h

ctype.hgnome-vfs-module-2.0 libxml pppdtuxmodule.h

curlgnu libxslt pr29.hucontext.h

curses.h gnu-versions.hlimits.hprintf.h ulimit.h

db.hgnutls link.h profile.h unctrl.h

dbgpg-error.hlinux protocols unistd.h

db_185.h gpm.h locale.hpthread.h u.h

db_cxx.h grp.h lockdev.hpty.hupp.h

dbus-1.gssapi lvm2cmd.hpunycode.h ustat.h

dirent.h gssapi.hmagic.h pwd.hutime.h

dlfcn.hgssrpc malloc.hpycairo utmp.h

drmgtk-2. mallocvar.hpygtk-2.0 utmpx.h

e2pgtk-unix-print-2.0 math.h python2.4 uuid

eelhal mcheck.hrdmavalues.h

efihesiod.hmemory.hre_comp.h video

elf.hiconv.h menu.h readline vorbis

endian.h idn-free.hmetacityregex.h wait.h

entities.h idn-int.hmntent.hregexp.h wchar.h

envz.hidna.h monetary.hresolv.h wctype.h

err.hieee754.hmp.h rpcwordexp.h

errno.hifaddrs.hmpf2mpfr.hrpcsvcxf86drm.h

error.hinitreq.hmpfr.h rpmxlocale.h

esd.hinttypes.hmpfrxx.hsaslxmlsec1

etiscsi_list.hmqueue.hsched.h xulrunner-sdk-1.9.2

eti.hjconfig. scsizconf.h

evolution-data-server-1.12 jerror.hncurses search.h zlib.h

execinfo.h jmorecfg.hncurses.hsecurity zutil.h

expat.hjpeglib.hncurseswselinux

expat_external.hkerberosIVnet semaphore.h

usr include 下面

/usr/include/

如何使用modprobe命令来加载,卸载和查看模块

1. 列出可用的内核模块

使用 modprobe -l 命令可以列出所有可用的内核模块

$ modprobe -l | less

kernel/arch/x86/kernel/cpu/mcheck/mce-inject.ko

kernel/arch/x86/kernel/cpu/cpufreq/e_powersaver.ko

kernel/arch/x86/kernel/cpu/cpufreq/p4-clockmod.ko

kernel/arch/x86/kernel/msr.ko

kernel/arch/x86/kernel/cpuid.ko

kernel/arch/x86/kernel/apm.ko

kernel/arch/x86/kernel/scx200.ko

kernel/arch/x86/kernel/microcode.ko

kernel/arch/x86/crypto/aes-i586.ko

kernel/arch/x86/crypto/twofish-i586.ko

2. 列出当前已加载的内核模块

上面的modprobe命令列出了所有可用的内核模块,我们可以使用lod命令列出当前Linux内核已加载的模块。

$ lod | less

soundcoresnd

ppdev

snd_page_alloc1 snd_pcm

pouse

lp

3. 安装新模块到内核

要向内核插入一个新模块,使用modprobe加模块名就行了:

$ sudo modprobe vmhgfs

当模块被加载后,更好使用lod来验证一下

$ lod | grep vmhgfs

vmhgfs

模块的名称使用.ko后缀,如果你想知道特定的模块文件到底存放在哪里,可以使用modprobe命令并将输出定向到grep命令即可:

$ modprobe | grep vmhgfs

misc/vmhgfs.ko

$ cd /lib/modules/2.6.31-14-generic/misc

$ ls vmhgfs*

vmhgfs.ko

注:也可以使用 inod 命令安装新模块到内核。

. 使用另一个名字加载模块来防止冲突

考虑下这个问题,有些情况下我们想要向内核加载一个新模块,但是新模块的名称与一个已加载模块相同,但是这两个模块的功能和作用并不相同。

由于一些很奇怪的原因,你想要加载到内核的模块和别的已加载模块重名,那么这时候你需要使用另一个名字来加载你的模块,可以使用 modprobe 命令的 -o 选项来达到这个目的:

$ sudo modprobe vmhgfs -o vm_hgfs

$ lod | grep vm_hgfs

vm_hgfs

5. 卸载模块

如果你已经加载一些模块到内核中(比如测试用),你或许想要把它们从内核卸载(或删除)。使用 modprobe 的 -r 选项可以达到这个目的:

modprobe -r vmhgfs

关于mcheck linux的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


编辑:一起学习网

标签:错误,模块,内核,硬件,系统