首页 > Web开发 > 详细

php curl 中的gzip压缩性能测试

时间:2014-02-14 23:54:22      阅读:724      评论:0      收藏:0      [点我收藏+]

前因:

  

1
请求接口次数很多,每日两亿多次,主要是有些接口返回数据量很大高达110KB(为了减少请求次数,将多个接口合并成一个导致的)。<br>后端接口的nginx已经开启gzip,所以做个测试,看看是否在请求时使用压缩解压

  

 

php CURL 的扩展安装这里就不说了

用到的curl的两个参数

1
2
//在http 请求头加入 gzip压缩<br>curl_setopt($ch, CURLOPT_HTTPHEADER, array(‘Accept-Encoding:gzip‘));
//curl返回的结果,采用gzip解压<br>curl_setopt($ch, CURLOPT_ENCODING, "<span style="line-height: 1.5;">gzip</span>");

 

1、不使用压缩解压

1
2
3
4
5
6
7
8
9
10
11
12
$s1 = microtime(true);
$ch = curl_init();
for($i=0; $i<100;$i++){
    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";

  测试结果    请求100次平均耗时 2.1s   0.021s/次

   

2、使用压缩解压

1
2
3
4
5
6
7
8
9
10
11
12
13
14
$s1 = microtime(true);
$ch = curl_init();
for($i=0; $i<100;$i++){
    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";

  测试结果    请求100次平均耗时 2.6s   0.026/次

 

结果

1
2
1、不使用压缩比使用压缩 请求一次快 5ms
2、千兆网,在局域网内传输这些数据大概是 0.7ms

 

结论

暂时不使用 curl 的压缩和解压

php curl 中的gzip压缩性能测试

原文:http://www.cnblogs.com/fengwei/p/3549124.html

(1)
(1)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!