PHP CURL HTTPS内存泄露问题

还原场景:经过一直运行脚本,向微信用户发送模板消息,发现运行了一段时间,内存就爆了,而后立马看了一下代码,发现跟其余的消息逻辑如出一辙,惟一不同的就是请求了微信的接口;而后继续开始找问题,发现当时使用了curl请求微信的接口,源码以下:php

function http_request($url = '', $message = '')
{
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
    curl_setopt($ch, CURLOPT_POSTFIELDS, $message);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_HTTPHEADDER, array(\
        'Content-Type: application/json',
        'Content-Length: ' . strlen($message)
    ));
    $result = curl_exec($ch);
    if (curl_errno($ch)) {
        print curl_error($ch);    
    }
    curl_close($ch);
    return $result;
}

  

而后,运维就通知我,今天凌晨服务器的内存爆了,这个脚本也被重启了;json

猜想一:是否昨天晚上有大批量的推送,由于以前出现过这个问题,致使了内存爆了,而后赶忙查了一下后台,发现没有推送被建立,排除;服务器

猜想二:调用微信接口存在问题,而后运维把监控的状况发了过来;微信

解决办法:app

一、更新curl模块;运维

二、禁用ssl验证;curl

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
相关文章
相关标签/搜索