我写了server.php来接受客户端通过tcp套接字的连接。 和我有使用在背景上连续运行Php脚本
set_time_limit(0);
include_once("include/class.db.php");
while (true)
{
receive_message('x.x.x.x','8855',50);
}
function receive_message($ipServer,$portNumber,$nbSecondsIdle)
{
// creating the socket...
$socket = stream_socket_server('tcp://'.$ipServer.':'.$portNumber, $errno, $errstr);
if (!$socket)
{
echo "$errstr ($errno)<br />\n";
}
else
{
// while there is connection, i'll receive it... if I didn't receive a message within $nbSecondsIdle seconds, the following function will stop.
while ($conn = @stream_socket_accept($socket,$nbSecondsIdle))
{
$message= fread($conn, 1024);
if($message!=''){
echo 'I have received that : '.$message;
// insert into database
$sql = "insert into `data_log` (`id`,`message_text`) values (NULL,'$message')";
$query=mysql_query($sql) or die(mysql_error() . "<br>" . $sql);
}
fputs ($conn, "OK\n");
fclose ($conn);
}
fclose($socket);
}
}
然后我运行
nohup php server.php >/dev/null 2>&1 &
运行在后台服务器。它一切正常。但套接字在几个小时后会自动关闭,或者让php脚本在几个小时后结束。因为我的需要是在后台运行脚本,直到我手动停止它。 可能是什么问题? 在此先感谢
好吧 - 您可以开始排除故障,将您的程序输出管道输出到日志文件而不是/ dev/null。作为一个初步措施,如果你的脚本仍在运行,你可以不时地写一个cronjob检查,如果不是的话,重新启动它。 –
可能经过一段时间db连接被关闭,脚本执行停止,或者你的内存不足。请首先检查您的连接。 –
@FranzGleichmann使用文件而不是/ dev/null在一天内创建一个大约20GB的大文件。所以我使用/ dev/null –