新聞中心
這篇文章主要介紹php curl中g(shù)zip的壓縮性能測(cè)試的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
具體如下:
前因:
請(qǐng)求接口次數(shù)很多,每日兩億多次,主要是有些接口返回?cái)?shù)據(jù)量很大高達(dá)110KB(為了減少請(qǐng)求次數(shù),將多個(gè)接口合并成一個(gè)導(dǎo)致的)。
后端接口的nginx已經(jīng)開啟gzip,所以做個(gè)測(cè)試,看看是否在請(qǐng)求時(shí)使用壓縮解壓
php CURL 的擴(kuò)展安裝這里就不說了
用到的curl的兩個(gè)參數(shù)
//在http 請(qǐng)求頭加入 gzip壓縮 curl_setopt($ch, CURLOPT_HTTPHEADER, array('Accept-Encoding:gzip')); //curl返回的結(jié)果,采用gzip解壓 curl_setopt($ch, CURLOPT_ENCODING, "gzip");
1、不使用壓縮解壓
$s1 = microtime(true); $ch = curl_init(); for($i=0; $i<100;$i++){ $url="http://192.168.0.11:8080/xxxxx/xxxxx?"; curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_TIMEOUT, 3); $data = curl_exec($ch); } curl_close($ch); echo microtime(true)-$s1; echo "\n";
測(cè)試結(jié)果:
請(qǐng)求100次平均耗時(shí) 2.1s 0.021s/次
2、使用壓縮解壓
$s1 = microtime(true); $ch = curl_init(); for($i=0; $i<100;$i++){ $url="http://192.168.0.1:8080/xxxxx/xxxxx?"; curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_TIMEOUT, 3); curl_setopt($ch, CURLOPT_HTTPHEADER, array('Accept-Encoding:gzip')); curl_setopt($ch, CURLOPT_ENCODING, "gzip"); $data = curl_exec($ch); } curl_close($ch); echo microtime(true)-$s1; echo "\n";
測(cè)試結(jié)果:
請(qǐng)求100次平均耗時(shí) 2.6s 0.026/次
結(jié)果分析:
1、不使用壓縮比使用壓縮 請(qǐng)求一次快 5ms
2、千兆網(wǎng),在局域網(wǎng)內(nèi)傳輸這些數(shù)據(jù)大概是 0.7ms
結(jié)論:
暫時(shí)不使用 curl 的壓縮和解壓
以上是“php curl中g(shù)zip的壓縮性能測(cè)試的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
本文題目:phpcurl中g(shù)zip的壓縮性能測(cè)試的示例分析-創(chuàng)新互聯(lián)
文章地址:http://ef60e0e.cn/article/cdogeh.html