Есть:use IO::Socket;
$SET_port=4141;
$bind=IO::Socket::INET->new(Listen=>5,Reuse=>1,LocalPort=>$SET_port);while($client=$bind->accept()) {
unless(fork()){
$client->recv($data,2048);
[здесь идёт обработка полученных данных]
while (1){
[здесь мы генерируем новые данные, кои будем передавать]
if (__ЧТО?__){$client->send($la_la_rezult);}else{&zacehlit(); exit;}
} # while (1)
} # unless(fork())
} # while($client=$bind->accept())
Суть задачи - определить, что клиент зацепившийся открытый порт (в данном случае 4141) ещё не закрыл соединение, перед тем как передавать ему данные и если прикрыл, то вызвать "zacehlit()".
То есть что должно быть вместо "__ЧТО?__"?
Перечитал man IO::Socket и увидел:if ($client->connected){$client->send($la_la_rezult);}else{&zacehlit(); exit;}
>Перечитал man IO::Socket и увидел:
>
>if ($client->connected){$client->send($la_la_rezult);}else{&zacehlit(); exit;}Ну и что?
помогло?Я в свое время писал сетевой демон на перле. И стояла анологичная задача.
Eсли другая сторона сокета закрывала его инструкцией close - все шоколадно отлавливалось на другой стороне (я это реализовал через обработку ошибки, возвращаемой функцией read()).
Но если связь рвалась (неполадки сети etc...) обе стороны думали, что соке жив и могли писать и читать в(из) мертвого сокета.
Минут через 20 - 30 (я так понял системный тайм-аут, но изменить его так и узнал где) обе стороны что называется "отдуплялись" что сокета нет....
Решил плоблему банальной "перепиновкой" на уровне приложения.
Работает. Год уже.