From: flugelaar at pandora dot be
Operating system: Linux Slackware 9.0
PHP version: 5CVS-2003-08-29 (dev)
PHP Bug Type: Sockets related
Bug description: stream_set_blocking() doesn't set non-blocking mode
Description:
------------
Fgets() keeps blocking when I try to make a socket from
stream_socket_accept() non-blocking. The listening socket is also
non-blocking.
Reproduce code:
---------------
This code is still blocking on the fgets:
$conn = @stream_socket_accept($hsock,1,&$host);
if (!$conn) return;
echo "Got connection from ".$host."\n";
stream_set_blocking($conn,false);
$get = '';
$loop = 0;
while ($loop <= 10) { $getl = trim(fgets($conn)); $loop++; if
(empty($getl)) { echo "End of headers\n"; break; }else{ $get .=
$getl."\n"; } }
This is the code that created the $hsock :
$hsock = stream_socket_server('tcp://'.$bind.':'.$port, $errno, $errstr);
if (!$hsock) die ('Listening socket failed: '.$errstr);
if (!socket_set_blocking($hsock,false)) echo "Socket (listening) set
nonblock failed\n";
$bind is 0.0.0.0 and port is 3333
Expected result:
----------------
It shouldn't hang on the fgets() because this script handles two sockets.
And the other one times out when fgets() hangs untill something is
recieved.
Actual result:
--------------
Fgets() keeps blocking so my other connection times out.
--
Edit bug report at http://bugs.php.net/?id=25309&edit=1
--
Try a CVS snapshot (php4): http://bugs.php.net/fix.php?id=25309&r=trysnapshot4
Try a CVS snapshot (php5): http://bugs.php.net/fix.php?id=25309&r=trysnapshot5
Fixed in CVS: http://bugs.php.net/fix.php?id=25309&r=fixedcvs
Fixed in release: http://bugs.php.net/fix.php?id=25309&r=alreadyfixed
Need backtrace: http://bugs.php.net/fix.php?id=25309&r=needtrace
Try newer version: http://bugs.php.net/fix.php?id=25309&r=oldversion
Not developer issue: http://bugs.php.net/fix.php?id=25309&r=support
Expected behavior: http://bugs.php.net/fix.php?id=25309&r=notwrong
Not enough info: http://bugs.php.net/fix.php?id=25309&r=notenoughinfo
Submitted twice: http://bugs.php.net/fix.php?id=25309&r=submittedtwice
register_globals: http://bugs.php.net/fix.php?id=25309&r=globals
PHP 3 support discontinued: http://bugs.php.net/fix.php?id=25309&r=php3
Daylight Savings: http://bugs.php.net/fix.php?id=25309&r=dst
IIS Stability: http://bugs.php.net/fix.php?id=25309&r=isapi
Install GNU Sed: http://bugs.php.net/fix.php?id=25309&r=gnused