前端开发中的性能那点事(二)巧用curl 并发减少后端访问时间

PHP并发请求实践
本文介绍如何使用PHP的curl多路复用功能实现并发请求多个HTTP接口,通过对比单个顺序请求的方式,展示了并发请求能够显著减少页面加载时间,提高整体效率。

前言:
在我们平时的程序中难免出现同时访问几个接口的情况,平时我们用curl进行访问的时候,一般都是单个、顺序访问,假如有3个接口,每个接口耗时500毫秒那么我们三个接口就要花费1500毫秒了,这个问题太头疼了严重影响了页面访问速度,有没有可能并发访问来提高速度呢?今天就简单的说一下,利用curl并发来提高页面访问速度,
希望大家多指导。
1、老的curl访问方式以及耗时统计

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<?php
functioncurl_fetch($url,$timeout=3){
    $ch= curl_init();
    curl_setopt($ch, CURLOPT_URL,$url);
    curl_setopt($ch, CURLOPT_TIMEOUT,$timeout);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    $data= curl_exec($ch);
    $errno= curl_errno($ch);
    if($errno>0) {
        $data= false;
    }
    curl_close($ch);
    return$data;
}
functionmicrotime_float()
{
   list($usec,$sec) =explode(" ", microtime());
   return((float)$usec+ (float)$sec);
}
$url_arr=array(
     "taobao"=>" http://www.taobao.com",
     "sohu"=>" http://www.sohu.com",
     "sina"=>" http://www.sina.com.cn",
     );
 $time_start= microtime_float();
 $data=array();
 foreach($url_arras$key=>$val)
 {
     $data[$key]=curl_fetch($val);
 }
 $time_end= microtime_float();
 $time=$time_end-$time_start;
 echo"耗时:{$time}";
?>

耗时:0.614秒
2、curl并发访问方式以及耗时统计

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
<?php
functioncurl_multi_fetch($urlarr=array()){
    $result=$res=$ch=array();
    $nch= 0;
    $mh= curl_multi_init();
    foreach($urlarras$nk=>$url) {
        $timeout=2;
        $ch[$nch] = curl_init();
        curl_setopt_array($ch[$nch],array(
        CURLOPT_URL =>$url,
        CURLOPT_HEADER => false,
        CURLOPT_RETURNTRANSFER => true,
        CURLOPT_TIMEOUT =>$timeout,
        ));
        curl_multi_add_handle($mh,$ch[$nch]);
        ++$nch;
    }
    /* wait for performing request */
    do{
        $mrc= curl_multi_exec($mh,$running);
    }while(CURLM_CALL_MULTI_PERFORM ==$mrc);
 
    while($running&&$mrc== CURLM_OK) {
        // wait for network
        if(curl_multi_select($mh, 0.5) > -1) {
            // pull in new data;
            do{
                $mrc= curl_multi_exec($mh,$running);
            }while(CURLM_CALL_MULTI_PERFORM ==$mrc);
        }
    }
 
    if($mrc!= CURLM_OK) {
        error_log("CURL Data Error");
    }
 
    /* get data */
    $nch= 0;
    foreach($urlarras$moudle=>$node) {
        if(($err= curl_error($ch[$nch])) =='') {
            $res[$nch]=curl_multi_getcontent($ch[$nch]);
            $result[$moudle]=$res[$nch];
        }
        else
        {
            error_log("curl error");
        }
        curl_multi_remove_handle($mh,$ch[$nch]);
        curl_close($ch[$nch]);
        ++$nch;
    }
    curl_multi_close($mh);
    return $result;
}
$url_arr=array(
     "taobao"=>" http://www.taobao.com",
     "sohu"=>" http://www.sohu.com",
     "sina"=>" http://www.sina.com.cn",
     );
functionmicrotime_float()
{
   list($usec,$sec) =explode(" ", microtime());
   return((float)$usec+ (float)$sec);
}
$time_start= microtime_float();
$data=curl_multi_fetch($url_arr);
$time_end= microtime_float();
$time=$time_end-$time_start;
 echo"耗时:{$time}";
?>

耗时:0.316秒
帅气吧整个页面访问后端接口的时间节省了一半
3、curl相关参数
来自:http://cn2.php.net/manual/en/ref.curl.php
curl_close — Close a cURL session
curl_copy_handle — Copy a cURL handle along with all of its preferences
curl_errno — Return the last error number
curl_error — Return a string containing the last error for the current session
curl_exec — Perform a cURL session
curl_getinfo — Get information regarding a specific transfer
curl_init — Initialize a cURL session
curl_multi_add_handle — Add a normal cURL handle to a cURL multi handle
curl_multi_close — Close a set of cURL handles
curl_multi_exec — Run the sub-connections of the current cURL handle
curl_multi_getcontent — Return the content of a cURL handle if CURLOPT_RETURNTRANSFER is set
curl_multi_info_read — Get information about the current transfers
curl_multi_init — Returns a new cURL multi handle
curl_multi_remove_handle — Remove a multi handle from a set of cURL handles
curl_multi_select — Wait for activity on any curl_multi connection
curl_setopt_array — Set multiple options for a cURL transfer
curl_setopt — Set an option for a cURL transfer
curl_version — Gets cURL version information

转载于:https://my.oschina.net/u/574366/blog/143826

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值