地址: 作者:Jekkay Hu
关键词:Windows,curl,ssl, visual c++ 2005, libcurl, https, openssl, 内存泄露
时间: 2014/3/3
精灵族都是高富帅和白富美~~~~~ |
1. 问题描述
HTTP和HTTPS的页面。但程序运行时间一久,电脑就特别的卡,仔细研究发现小小程序几乎把电脑的内存吃光了,显然这是内存泄露的问题。
内存泄露检测库VLD(Visual leak detection)编译进去,用Debug(MTD编译)模式调试。调试了一整天,检测出内存泄露都发生在curl_easy_perform这个函数里面,查看调用栈时,泄露的内存都是在openssl库里面,由于没有openssl pdb调试符号,所以无法确定到底是其中的哪个函数出现问题的。
我重新建了一个新的 MFC工程testlibcurl,然后调用libcurl抓取Web页面一百次,奇怪的是这次居然没有发生内存泄露,不管是抓取HTTP还是HTTPS页面,curl_easy_perform函数这次都没有内存泄露,好奇怪!仔细对比了一下这两个工程的不同之处,才发现前者是多线程,后者是单线程。为了验证是否多线程的原因,我在testlibcurl工程中新建了一个线程,在线程中抓取HTTPS页面,这次居然就出现了内存泄露!!!然后,我多测试了几次,测试的结果有点让人失望吧,现在总结使用含静态openssl的libcurl库问题如下。
1. 在单线程中,访问HTTP和HTTPS都不会发生内存泄露
2. 在多线程中,访问HTTP不会发生内存泄露
3. 在多线程中,访问HTTPS页面,curl_easy_peform会发生内存泄露,从调用栈来看是内存泄露的地方是在openssl里面。
2. 我的解决方案
放弃使用含有静态的Openssl库的libcurl,只能使用openssl的动态链接库,才不会发生内存泄露。
胡杨, Jekkay Hu
2014/3/3