SSL_library_init的内存泄露解决

本文揭示了SSL_library_init调用load_builtin_compressions导致的内存泄露问题。在openssl环境中,由于缺乏相应的释放方法,调用该函数会留下未释放的内存。通过在ssl/ssl_ciph.c文件中新增SSL_free_compressions函数,可在清理资源时调用,有效避免内存泄露。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SSL_library_init调用load_builtin_compressions,但在最终释放openssl环境时,没有提供释放的方法,会导致内存泄露。

==30378== 
==30378== HEAP SUMMARY:
==30378==     in use at exit: 1,704 bytes in 3 blocks
==30378==   total heap usage: 5,704 allocs, 5,701 frees, 1,563,697 bytes allocated
==30378== 
==30378== 32 bytes in 1 blocks are still reachable in loss record 1 of 3
==30378==    at 0x4C29EA3: malloc (vg_replace_malloc.c:309)
==30378==    by 0x57739F7: CRYPTO_malloc (mem.c:351)
==30378==    by 0x57A319E: sk_new (stack.c:162)
==30378==    by 0x574ADF2: load_builtin_compressions (ssl_ciph.c:521)
==30378==    by 0x574ADF2: SSL_COMP_get_compression_methods (ssl_ciph.c:2049)
==30378==    by 0x575108E: SSL_library_init (ssl_algs.c:160)
 

解决方法如下

在\ssl\ssl_ciph.c最下增加如下代码,然后释放openssl资源时,调用SSL_free_compressions即可:

#ifndef OPENSSL_NO_COMP 
// add by qsy;
void SSL_free_compressions(void) __attribute__ ((destructor)); 
void SSL_free_compressions(void) 

    if (ssl_comp_methods != NULL) 
        { 
        sk_SSL_COMP_free(ssl_comp_methods); 
        ssl_comp_methods = NULL; 
        } 

#endif 
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值