2013-05-08 152 views
0

嗨我想在我的项目中加入一个函数,它将ping我的应用程序服务器并查看它们是否正在运行。问题是,每次我尝试使用这个函数时,它总是返回它们还活着,即使我在我的本地环境中,并且这些IP地址上没有服务器。发生什么了?fsockopen()总是返回true

这里是我的功能:

function ping($host, $port, $timeout) { 
    if($fp = fsockopen($host,$port,$errCode,$errStr,$timeout)){ 
     return 'Alive'; 
    } else { 
     return 'Not alive'; 
    } 
    fclose($fp); 
} 

这里是我正在调用该函数:

foreach ($appservers as $key => $value) { 
     echo ping($value['privateip'] , 80, 1).'<br/>'; 
    } 

这里是我的服务器变量数组:

$appservers = array(
'app1' => array(
    'publicdns' => 'app1.xxxx.com', 
    'privateip' => '1.1.1.101', 
    'alive' => NULL, 
    'active_users' => NULL 
), 

'app2' => array(
    'publicdns' => 'app2.xxxx.com', 
    'privateip' => '1.1.1.102', 
    'alive' => NULL, 
    'active_users' => NULL 
), 

'app3' => array(
    'publicdns' => 'app3.xxxx.com', 
    'privateip' => '1.1.1.103', 
    'alive' => NULL, 
    'active_users' => NULL 
), 

'app4' => array(
    'publicdns' => 'app4.xxxx.com', 
    'privateip' => '1.1.1.104', 
    'alive' => NULL, 
    'active_users' => NULL 
) 

);

回答

0

之前就看到过这个问题,您正在使用DNS服务将不存在的域解析为服务器,该服务器为您提供了一个“友好”的错误页面,并返回200个响应代码。

有关此问题的更多详细信息,请参阅:get_headers Inconsistency

您可以DavidRandom解决方案解决它

var_dump(ping("stackoverflow.com", 30, 1)); // port 30 return false 
var_dump(ping("stackoverflow.com", 80, 1)); // port 80; returns 0.49000000953674 

你的函数修改

function ping($host, $port, $timeout) { 
    $a = gethostbyname('idontexist.tld'); 
    $b = gethostbyname($host); 

    if ($a == $b) 
     return false; 

    $time = microtime(true); 
    $fp = @fsockopen($host, $port, $errCode, $errStr, $timeout); 
    $time = microtime(true) - $time; 
    if ($fp) { 
     fclose($fp); 
     return $time; 
    } else { 
     return false; 
    } 
} 
+0

进行更新真棒感谢。想知道fsockopen之前的@符号吗? – slick1537 2013-05-08 12:04:08

+0

坏消息是,我只是想更新的代码,它是返回ping时间....'0.010555028915405 0.010455846786499 0.010455846786499 0.0095298290252686' – slick1537 2013-05-08 12:08:46

+0

@KevinMcKinney错误supression ....如果你可以给这个IP我想2〜测试我自己 – Baba 2013-05-08 12:11:02