還原場景:通過一直運行腳本,向微信用戶發送模板消息,發現運行了一段時間,內存就爆了,然后立馬看了一下代碼,發現跟其他的消息邏輯一模一樣,唯一不一樣的就是請求了微信的接口;然后繼續開始找問題,發現當時使用了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);
