我见过其他人有这个问题,但也许我可以解释一下我的情况,你可以指出问题所在。
我得到'警告:socket_bind():无法绑定地址[98]:地址已在使用中'错误。
情况就是这样。我正在使用Web应用程序触发另一个程序来执行任务(从网页界面)。该程序的结果通过套接字发送到我正在侦听套接字的Web应用程序。
首先我创建并打开套接字,然后我触发另一个程序,然后当该程序完成时,它应该通过套接字发回其结果。
第一次尝试时效果很好。然后下一次尝试(我多次触发此过程)我在尝试打开套接字时遇到上面的套接字绑定错误,显然套接字仍然是绑定的。
我等一下,我可以再次成功运行该过程。我认为套接字连接超时。
我不知道问题是因为我的套接字代码的结构方式,或者问题出在我触发的外部程序中。我不太了解外部程序的内部结构,因为它是由其他人构建的jar文件。
继承了我用于创建和处理套接字的代码。我只是在php.net上使用了一个例子并根据我的需要对其进行了修改。
$port1 = 15000;
// configure the socket
error_reporting(E_ALL);
set_time_limit(0);
ob_implicit_flush();
$address = '127.0.0.1';
$port2 = 54321;
$sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
$error = 'none';
if ($sock) {
if (socket_bind($sock, $address, $port2)) {
if (socket_listen($sock, 5)) {
// trigger external process
if (start_calibration()) {
$buf = array();
// listen to the socket for incoming messages
do {
// if incomming connection is not accepted break out and close socket
if (($msgsock = socket_accept($sock)) === false) {
break;
}
do {
// if cant read socket then break out and close socket
if (false === ($buf = socket_read($msgsock, 2048, PHP_BINARY_READ))) {
break 2;
}
$buf = unpack('C*', $buf);
socket_close($msgsock);
break 2;
} while (true);
socket_close($msgsock);
} while (true);
socket_close($sock);
// code to handle data recieved through the socket
}
else {
// start_calibration failed
$error = 'start_calibration failed';
socket_close($sock);
}
}
else {
// socket_listen failed
$error = 'socket_listen failed';
socket_close($sock);
}
}
else {
// socket_bind failed
$error = 'socket_bind failed';
socket_close($sock);
}
}
else {
// socket_create failed
$error = 'socket_create failed';
}
$data['error'] = $error;
echo json_encode($data);
另外,如果“socket_bind”,“socket_listen”等行出现问题,是否有更有效的方法来处理套接字的关闭?
答案 0 :(得分:2)
您是否尝试在套接字上设置标记SO_REUSEADDR
?
socket_set_option
的{{3}}中有一个示例。