• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php curl 中的gzip压缩性能测试_php

php 搞代码 3年前 (2018-06-21) 221次浏览 已收录 0个评论

前因:

 
  
 
1
请求接口次数很多,每日两亿多次,主要是有些接口返回数据量很大高达110KB(为了减少请求次数,将多个接口合并成一个导致的)。<br>后端接口的nginx已经开启gzip,所以做个测试,看看是否在请求时使用压缩解压
  
 
 
 
php CURL 的扩展安装这里就不说了
 
用到的curl的两个参数
 
 
//在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、不使用压缩解压
 
 
$s1 = microtime(true);
$ch = curl_init();
for($i=0; $i<100;$i++){
    $url="http://192.168.0.11:8080/xxxxx/xxxxx?&quot;;
    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、使用压缩解压
 
 
$s1 = microtime(true);
$ch = curl_init();
for($i=0; $i<100;$i++){
    $url="http://192.168.0.1:8080/xxxxx/xxxxx?&quot;;
    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、不使用压缩比使用压缩 请求一次快 5ms
2、千兆网,在局域网内传输这些数据大概是 0.7ms
 

欢迎大家阅读php curl 中的gzip压缩性能测试_php》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址