当前位置:首页 > PHP教程 > php应用 > 列表

php使用curl并发减少后端访问时间的方法分析

发布:smiling 来源: PHP粉丝网  添加日期:2021-08-03 15:55:29 浏览: 评论:0 

本文实例讲述了php使用curl并发减少后端访问时间的方法。分享给大家供大家参考,具体如下:

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

1、老的curl访问方式以及耗时统计

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

耗时:0.614秒

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

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

耗时:0.316秒

帅气吧整个页面访问后端接口的时间节省了一半

3、curl相关参数

  1. curl_close — Close a cURL session 
  2. curl_copy_handle — Copy a cURL handle along with all of its preferences 
  3. curl_errno — Return the last error number 
  4. curl_error — Return a string containing the last error for the current session 
  5. curl_exec — Perform a cURL session 
  6. curl_getinfo — Get information regarding a specific transfer 
  7. curl_init — Initialize a cURL session 
  8. curl_multi_add_handle — Add a normal cURL handle to a cURL multi handle 
  9. curl_multi_close — Close a set of cURL handles 
  10. curl_multi_exec — Run the sub-connections of the current cURL handle 
  11. curl_multi_getcontent — Return the content of a cURL handle if CURLOPT_RETURNTRANSFER is set 
  12. curl_multi_info_read — Get information about the current transfers 
  13. curl_multi_init — Returns a new cURL multi handle 
  14. curl_multi_remove_handle — Remove a multi handle from a set of cURL handles 
  15. curl_multi_select — Wait for activity on any curl_multi connection 
  16. curl_setopt_array — Set multiple options for a cURL transfer 
  17. curl_setopt — Set an option for a cURL transfer 
  18. curl_version — Gets cURL version information

Tags: curl并发减少 php后端访问

分享到: