前因:
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 的压缩和解压