php curl中gzip的压缩性能测试实例分析
本文实例分析了phpcurl中gzip的压缩性能测试。分享给大家供大家参考,具体如下:
前因:
请求接口次数很多,每日两亿多次,主要是有些接口返回数据量很大高达110KB(为了减少请求次数,将多个接口合并成一个导致的)。
后端接口的nginx已经开启gzip,所以做个测试,看看是否在请求时使用压缩解压
phpCURL的扩展安装这里就不说了
用到的curl的两个参数
//在http请求头加入gzip压缩 curl_setopt($ch,CURLOPT_HTTPHEADER,array('Accept-Encoding:gzip')); //curl返回的结果,采用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); echomicrotime(true)-$s1; echo"\n";
测试结果:
请求100次平均耗时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); echomicrotime(true)-$s1; echo"\n";
测试结果:
请求100次平均耗时2.6s 0.026/次
结果分析:
1、不使用压缩比使用压缩请求一次快5ms
2、千兆网,在局域网内传输这些数据大概是0.7ms
结论:
暂时不使用curl的压缩和解压
更多关于PHP相关内容感兴趣的读者可查看本站专题:《phpcurl用法总结》、《PHP数组(Array)操作技巧大全》、《php排序算法总结》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。