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