PHP在2个远程服务器之间传输数据,最快的方法是什么?

时间:2011-12-09 07:04:31

标签: php

我有服务器A和服务器B交换一些数据。用户请求上的服务器A使用带有一些参数的简单file_get_content从服务器B提取数据,因此服务器B可以执行所有任务(数据库等)并将结果返回给A格式化并向用户显示。一切都在PHP中。

现在我感兴趣的是最快的方法是什么?我对服务器B的平均响应进行了一些测试和平均传输时间(~0.2秒)。在那0.2秒0.1秒。 aprox的。服务器B的运行时间(拉动数据调用少数数据库等)是什么意味着50kb的平均传输时间是0.1秒。 (服务器不在同一网络中)

我应该尝试:

  1. cURL insted of file_get_content?
  2. 或尝试使用套接字完成整个事情(我从不使用PHP中的套接字工作,但我可以轻松地做到这一点,以此方式跳过Web服务器)
  3. 还是第三个?
  4. 我认为在缩短连接建立时可以“找到”时间,因为现在,每个请求都是新连接启动(我的意思是单独的file_get_content调用,或者我错了?)

    请告诉我你在哪个方向上尝试的建议,或者如果你有更好的解决方案我正在听。

3 个答案:

答案 0 :(得分:13)

<强>卷曲

function curl($url)
{
    $ch = curl_init();
    curl_setopt ($ch, CURLOPT_URL,$url);
    curl_setopt ($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6");
    curl_setopt ($ch, CURLOPT_TIMEOUT, 60);
    curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
    $result = curl_exec ($ch);
    curl_close($ch);
    return $result;
}

<强>套接字:

function sockets($host) {
$fp = fsockopen("www.".$host, 80, $errno, $errstr, 30);
  $out = "GET / HTTP/1.1\r\n";
  $out .= "Host: www.".$host."\r\n";
  $out .= "Connection: Close\r\n\r\n";
  fwrite($fp, $out);
  $f='';
  while (!feof($fp)) {
    $f .= fgets($fp, 1024);
  }
return $f;
}

<强>的file_get_contents

 function fgc($url){
       return file_get_contents($url);
    }

<强> Multicurl

function multiRequest($data,$nobody=false,$options = array(), $oneoptions = array())
{
    $curls = array();
    $result = array();
    $mh = curl_multi_init();
    foreach ($data as $id => $d)
    {
        $curls[$id] = curl_init();
        $url = (is_array($d) && !empty($d['url'])) ? $d['url'] : $d;
        curl_setopt($curls[$id], CURLOPT_URL,            $url);
        curl_setopt($curls[$id], CURLOPT_HEADER,         0);
        curl_setopt($curls[$id], CURLOPT_RETURNTRANSFER, true);
        curl_setopt($curls[$id], CURLOPT_FOLLOWLOCATION,1);
        curl_setopt($curls[$id], CURLOPT_USERAGENT,"Mozilla/5.0(Windows;U;WindowsNT5.1;ru;rv:1.9.0.4)Gecko/2008102920AdCentriaIM/1.7Firefox/3.0.4");
        //curl_setopt($curls[$id], CURLOPT_COOKIEJAR,'cookies.txt');
        //curl_setopt($curls[$id], CURLOPT_COOKIEFILE,'cookies.txt');
        //curl_setopt($curls[$id], CURLOPT_NOBODY, $nobody);

        if (!empty($options))
        {
            curl_setopt_array($curls[$id], $options);
        }
        if (!empty($oneoptions[$id]))
        {
            curl_setopt_array($curls[$id], $oneoptions[$id]);
        }
        if (is_array($d))
        {
            if (!empty($d['post']))
            {

                curl_setopt($curls[$id], CURLOPT_POST,       1);
                curl_setopt($curls[$id], CURLOPT_POSTFIELDS, $d['post']);
            }
        }
        curl_multi_add_handle($mh, $curls[$id]);
    }
    $running = null;
    do
    {
        curl_multi_exec($mh, $running);
    }
    while($running > 0);
    foreach($curls as $id => $content)
    {
        $result[$id] = curl_multi_getcontent($content);
        //echo curl_multi_getcontent($content);
        curl_multi_remove_handle($mh, $content);
    }
    curl_multi_close($mh);
    return $result;
}

<强>试验:

$url = 'example.com';
$start = microtime(1);
for($i=0;$i<100;$i++)
curl($url);
$end = microtime(1);
echo "Curl:".($end-$start)."\n";

$start = microtime(1);
for($i=0;$i<100;$i++)
fgc("http://$url/");
$end = microtime(1);
echo "file_get_contents:".($end-$start)."\n";

$start = microtime(1);
for($i=0;$i<100;$i++)
sockets($url);
$end = microtime(1);
echo "Sockets:".($end-$start)."\n";

$start = microtime(1);
for($i=0;$i<100;$i++)
$arr[]=$url;
multiRequest($arr);
$end = microtime(1);
echo "MultiCurl:".($end-$start)."\n";
?>

<强>结果:

  • 卷曲:5.39667105675
    file_get_contents:7.99799394608
    套接字: 2.99629592896
    MultiCurl:0.736907958984

答案 1 :(得分:0)

  

什么是最快的方式?

将您的数据放在闪存盘上。

现在认真 来吧,它的网络很慢。你不能让它更快 为了使服务器A响应更快,请勿从服务器B请求数据。这是唯一的方法 您可以复制数据或对其进行缓存,或者只是放弃这种笨拙的设置 但只要您必须对每个用户的请求进行网络查找,它就会很慢。尽管你正在使用的方法。它不是hte方法,而是媒体。不是很明显吗?

答案 2 :(得分:-1)

您可以尝试另一种不同的方法:将远程文件系统挂载到本地计算机中。您可以使用sshfs执行此操作,这样您将获得encripted连接的额外安全性。

由于php不必处理连接协商和建立,因此效率可能更高。