li
  当前位置:主页 > 操作系统 > 文章内容
li
使用mtrace进行Linux系统下内存状况监测
来源: www.ixdba.net  作者: IXDBA.NET官方    时间:2008-03-23   阅读:13  
 内存溢出,对系统来说比较麻烦,也不好监测,大家可以尝试如下方法!

对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。Debug起来也是比较累人。其实Linux系统下有一个使用的工具可以帮忙来调试的,这就是Mtrace。Mtrace主要能够检测一些内存分配和泄漏的失败等。下面我们来学习一下它的用法。

使用Mtrace来调试程序有4个基本的步骤,需要用到GNU C 函数库里面的一些辅助的函数功能。

1.在需要跟踪的程序中需要包含头文件,而且在main()函数的最开始包含一个函数调用:mtrace()。由于在main函数的最开头调用了mtrace(),所以该进程后面的一切分配和释放内存的操作都可以由mtrace来跟踪和分析。

2.定义一个环境变量,用来指示一个文件。该文件用来输出log信息。如下的例子:

$export MALLOC_TRACE=mymemory.log

3.正常运行程序。此时程序中的关于内存分配和释放的操作都可以记录下来。

4.然后用mtrace使用工具来分析log文件。例如:

$mtrace testmem $MALLOC_TRACE

要注意的是,在很多嵌入式的环境中,并不提供export命令,也没有记录环境变量的文件。这时候难道就没有办法了么?呵呵,也许,唯一的办法就是把环境变量加到应用程序中。在Glibc库中有putenv函数,就是写入环境变量的。具体的请自己查手册。

int putenv (char *string) [Function]

设置好环境变量后。又有一个问题了:如果程序是自运行的,即没有终止的时候,那想在特定的地方,分析内存情况,怎么办呢?

呵呵,还是看Glibc!,调用muntrace函数,log文件就生成了。这时用mtrace命令分析log文件就可以啦。

下面是具体一个例子,大家可以看一下。

[hwang@langchao test]$ cat testmtrace.c
#include <>
#include
#include
int main()
{
char *hello;
mtrace();
hello = (char*) malloc(20);
sprintf(hello,"
hello world!");
return 1;
}
[hwang@langchao test]$export MALLOC_TRACE=mytrace.log
[hwang@langchao test]$ gcc testmtrace.c -o testmtrace
[hwang@langchao test]$./testmtrace
[hwang@langchao test]$ mtrace testmtrace mytrace.log
Memory not freed:
-----------------
Address Size Caller
0x08049860 0x14 at /usr/src/build/53700-i386/BUILD/glibc-2.2.4/csu/init.c:0



  上一篇: linux无法启动问题的解决   下一篇: 如何在Linux系统下查看OS系统块的...
li
 §相关评论  
 热点文章

·新手强烈推荐:linux入门11点建
·Unix学习方法-走向高手之路
·Linux性能分析和调整的基本原则
·你很陌生但是很适用的10个linu
·Oracle补丁3028673,解决单进程
·最近被aix 5305给折腾死了
·在AIX 5L上配置NFS Server/Cli
·在AIX 5L上配置与管理路由
·这个补丁影响的范围还是比较大
·在AIX 5L上使用绑定网卡(ethe
·使用pam_abl防止SSH遭暴力破解
li
 编辑推荐
·新手强烈推荐:linux入门11点建
·Unix学习方法-走向高手之路
·Linux性能分析和调整的基本原则
·你很陌生但是很适用的10个linu
·Oracle补丁3028673,解决单进程
·最近被aix 5305给折腾死了
·在AIX 5L上配置NFS Server/Cli
·在AIX 5L上配置与管理路由
·这个补丁影响的范围还是比较大
·在AIX 5L上使用绑定网卡(ethe
·使用pam_abl防止SSH遭暴力破解
li
 相关篇章
·linux无法启动问题的解决
·如何更改Linux操作系统下的显示默...
·linux系统管理:如何动态调整Linu...
·linux MRTG配置完整全功略
·unix/linux系统性能优化篇之交换...
·unix/linux使用sar命令进行系统监...
·hp服务器的网卡驱动安装文档
·HP DL380 G5安装SCO OpenServer ...
·Linux下常用压缩格式的压缩与解压...
·linux服务器安装网卡驱动一般步骤
·如何在Linux系统下查看OS系统块的...
·怎么知道Linux支持到多大的文件?
·linux利器:正则表达式30分钟入门...
·常用正则表达式资料
·shell 文件状态测试案例
·Linux系统命令Top/free的使用及参...
·linux下文本处理命令sed,awk,g...
·正则表达式中特殊字符详解
·Linux服务器网卡驱动安装及故障排...
·Linux内存管理机制中buffer和cac...
 
li
设为首页 | 关于我们 | 技术服务 | 收藏本站 | 网站地图 | 联系方式 | 本站友情连接