• PHP CURL HTTPS内存泄露问题


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

    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;
    }
    

      

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

    猜测一:是否昨天晚上有大批量的推送,因为之前出现过这个问题,导致了内存爆了,然后赶紧查了一下后台,发现没有推送被创建,排除;

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

    解决办法:

    1、更新curl模块;

    2、禁用ssl验证;

    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
    

      

  • 相关阅读:
    11 Jun 18 复习,HTTP
    11 Jun 18 Django
    8 Jun 18 复习,mysql
    8 Jun 18 Bootstrap
    7 Jun 18 复习,文件,函数,sorted,colletions
    7 Jun 18 Bootstrap
    pip 使用方法
    http协议 1.1
    mysql 的视图 触发器 事务 存储过程 内置函数 流程控制 索引
    day 29 守护进程/互斥锁/IPC通信机制/生产者消费者模型
  • 原文地址:https://www.cnblogs.com/timothy-lai/p/10577928.html
Copyright © 2020-2023  润新知