您现在的位置是:系统运维 >>正文
一种穷人式的内存泄露检测方式
系统运维5351人已围观
简介对于检测程序代码中的资源泄露问题,市面上已经有很多工具了,但是今天我再来介绍一种新的方式,这种方式不需要安装任何工具或者特定的编译器开关,也不需要第三方库。那就是:一直保持程序运行,直到泄露的原因自动 ...
对于检测程序代码中的种穷资源泄露问题 ,市面上已经有很多工具了,人式但是存泄测方今天我再来介绍一种新的方式 ,这种方式不需要安装任何工具或者特定的露检编译器开关,也不需要第三方库。种穷
那就是人式:一直保持程序运行,直到泄露的存泄测方原因自动水落石出。这是露检什么意思 ?每日自动压力测试通常是工程开发中的一个常规部分。建站模板有一些软件开发团队使用屏幕保护程序作为触发器,种穷其他团队使用自定义程序,人式还有一些团队需要手动启动压力测试 ,存泄测方但无论如何,露检在你下班回到家后 ,种穷你的人式计算机连接到测试服务器并接收一组整夜运行的测试。
这些压力测试经常出现的存泄测方一件事是这样或那样的内存泄漏,由压力测试团队识别,因为程序的资源使用率异常高 。但是源码库如何调试这些故障呢 ?这些机器没有使用泄漏检测工具运行特殊的检测版本 ,因此你无法使用它 。
相反 ,你可以一种新的检测思路:目标运行平台有着丰富的资源环境(target-rich environment)。
假设你的程序正在泄漏内存。连续大量使用十五小时后 ,程序开始出现内存不足故障。你显然在泄露一些东西,但是泄漏的具体是什么呢?
想想看:如果你泄露了一些东西 ,免费模板那么就会有很多 。而你没有泄漏的东西数量很少 。因此 ,如果你随机抓取进程快照,它很可能是一个泄漏的物体 !用数学术语来说,假设程序的正常内存使用量为 15 MB,但由于某种原因,你已经用完了 1693 MB 的动态分配内存。由于其中只有 15 兆字节是正常的源码下载内存使用量,因此其他 1678 兆字节必须是泄漏的数据 。如果从堆中转储随机地址,则找到泄漏对象的可能性大于 99%。
因此,随机抓取十几个地址并转储它们。你很可能会一遍又一遍地看到相同的数据模式 。那是程序的泄漏点 。如果它是一个具有虚拟方法的亿华云C++对象,转储 vtable 将快速识别它是什么类型的对象 。如果是 POD(Plain Old Data) 类型,通常可以通过查找字符串缓冲区或指向其他数据的指针来识别它是什么 。
最终结果可能会有所不同,但我发现这是一种非常成功的技术 ,可以把它想象成一种精神力量。
总结我一直在 Topomel Box 中使用一个外挂式的第三方库来检测内存泄露,云计算通过今天的文章 ,我明白了:我们可以什么也不做 ,就等它泄露 ,直至到达泄露原因是如此明显的时间点。
正所谓 :无为而无不为 。
Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“算法与编程”。http://www.bzli.cn/news/207e699786.html
相关文章
钱不要了!32% 的 CISO 考虑离职
系统运维BlackFog 一项研究结果显示,英美两国 32% 的 CISO 或其它 IT 安全 DM 正在考虑辞职,在这些安全高管中,三分之一的人将在未来六个月内离职。BlackFog 的研究探讨了网络安全专 ...
【系统运维】
阅读更多CISO激励团队并赢得团队尊重的三种方式
系统运维面对不断扩大的工作职能清单和复杂且往往令人困惑的报告结构,CISO到底需要哪些技能才能成功,以及他们如何最好地激励整个企业的团队并与其合作,其中存在着很多挑战。然而,最卓越的CISO具有共同的特点—— ...
【系统运维】
阅读更多秘密蔓延:一文了解如何保护您的秘密
系统运维您的开发团队多久以明文形式向同事发送 API 密钥或其他敏感数据?虽然这是共享数据最快的方式,但它绝对不是最安全的。当敏感数据最终出现在配置文件、源代码或明文中时,就会发生大量泄露。这个问题被称为秘密 ...
【系统运维】
阅读更多