你能否帮我在PHP中自定义以下cron脚本。该脚本在服务器中创建了许多后台进程。一天后,服务器正忙,MYSQL服务器崩溃。
以下脚本有什么问题。我需要这个脚本不断地监听特定的UDP端口。所以它被设置为一个cron jon,它将运行每一个mits。
set_time_limit(60);
class pingtype
{
function rotate()
{
$socket = socket_create(AF_INET, SOCK_DGRAM, SOL_UDP);
socket_bind($socket, '50.50.50.50', 9091);
$from = '';
$port = 0;
$bytes_received = socket_recvfrom($socket, $buf, 150, MSG_PEEK, $from, $port);
if ($bytes_received == -1)
{
die('An error occured while receiving from the socket');
echo "Received $buf from $from\n";
}
echo "Received $buf from remote address $from and remote port $port";
$hex_string_buf = "HEX: ".$this->strToHex($buf)." String: ".$buf;
$link = mysql_connect("localhost", "user_database", "123") or die ("Errror in connection ".mysql_error());
mysql_select_db("database") or die ("Error in select ".mysql_error());
$sql = "INSERT INTO socket SET contents='".$hex_string_buf."' ";
mysql_query($sql) or die ("Error in query ".mysql_error());
mysql_close($link);
// close socket and delete own .sock file
socket_close($socket);
usleep(1000);
}
function strToHex($string)
{
$hex='';
for ($i=0; $i < strlen($string); $i++)
{
$hex .= str_pad(dechex(ord($string[$i])), 3);
}
return $hex;
}
function hexToStr($hex)
{
$string='';
for ($i=0; $i < strlen($hex)-1; $i+=2)
{
$string .= chr(hexdec($hex[$i].$hex[$i+1]));
}
return $string;
}
}
for($i=1;$i<=6000;$i++)
{
$object_pingtype = new pingtype();
$object_pingtype->rotate();
}
答案 0 :(得分:0)
您的服务器超载。如果脚本每分钟运行一次,则执行以下代码:
for($i=1;$i<=6000;$i++)
{
$object_pingtype = new pingtype();
$object_pingtype->rotate();
}
归结为 6000 / 60~100 请求每秒。如果服务器没有足够的容量,它将无法在60秒内完成此脚本。然后启动一个新脚本等等。
在一天结束时,您的服务器将分解任务。
或者: