ID: 22297
User updated by: sp at m-me dot dk
Reported By: sp at m-me dot dk
Status: Open
Bug Type: Filesystem function related
Operating System: Windows
PHP Version: 4.3.2-dev
New Comment:
[EMAIL PROTECTED] writes:
"Your system has determined two alternative addresses to attempt to
contact for localhost and it attempts each alternative for
default_socket_timeout in seconds."
I'm not into how the file() function tries to read an URL, but after
what [EMAIL PROTECTED] writes it seems that it tries a couple of different
methods for reading the URL if the previous ones does not work. For me
it looks like the first 2 does not work, but the 3th does.
If that is right it then makes sense that the "max_execution_time" has
to be larger than "2 * default_socket_timeout" (because the first two
tries have to time out fist)..
Previous Comments:
------------------------------------------------------------------------
[2003-02-20 19:20:47] sp at m-me dot dk
I did a little test to try to find out when the script fails. It looks
like the script fails everytime the "max_execution_time" is smaller
than "2 * default_socket_timeout".
max_execution_time default_socket_timeout output
------------------------------------------------------
60 10 no error
25 10 no error
22 10 no error
21 10 no error
20 10 error
15 10 error
10 10 error
5 10 error
(when I write "no error" the script still runs for "2 *
default_socket_timeout" seconds though)
------------------------------------------------------------------------
[2003-02-20 19:02:57] sp at m-me dot dk
The script supplied gives the right output, but still takes
"default_socket_timeout * 2" seconds. I found that if I removed the
first line "set_time_limit(600);" the script faild again - Still I
could not get rid of the long timeout.
The output from the code was:
--------------------------------------------------
array(1) {
[0]=>
string(6) "foobar"
}
array(9) {
[0]=>
string(15) "HTTP/1.1 200 OK"
[1]=>
string(35) "Date: Fri, 21 Feb 2003 00:43:31 GMT"
[2]=>
string(29) "Server: Apache/2.0.43 (Win32)"
[3]=>
string(44) "Last-Modified: Tue, 18 Feb 2003 15:48:22 GMT"
[4]=>
string(23) "ETag: "37a6-6-d5528ab3""
[5]=>
string(20) "Accept-Ranges: bytes"
[6]=>
string(17) "Content-Length: 6"
[7]=>
string(17) "Connection: close"
[8]=>
string(44) "Content-Type: text/plain; charset=ISO-8859-1"
}
--------------------------------------------------
The output from the curl command (had to install Cygwin) was:
--------------------------------------------------
$ curl -i http://localhost/test/readfile/test.txt
HTTP/1.1 200 OK
Date: Fri, 21 Feb 2003 00:41:16 GMT
Server: Apache/2.0.43 (Win32)
Last-Modified: Tue, 18 Feb 2003 15:48:22 GMT
ETag: "37a6-6-d5528ab3"
Accept-Ranges: bytes
Content-Length: 6
Content-Type: text/plain; charset=ISO-8859-1
foobar
--------------------------------------------------
------------------------------------------------------------------------
[2003-02-20 14:39:52] [EMAIL PROTECTED]
Your system has determined two alternative addresses to attempt to
contact for localhost and it attempts each alternative for
default_socket_timeout in seconds.
For some reason it is not connecting successfully.
Please try the following script:
<?php
set_time_limit(600);
ini_set('default_socket_timeout', 5);
$x = file("http://localhost/test.txt");
var_dump($x);
var_dump($http_response_header);
?>
and report back here.
It would also help if you could try fetching the same url using:
curl -i http://localhost/test.txt
and paste the output here.
------------------------------------------------------------------------
[2003-02-20 06:42:29] sp at m-me dot dk
When setting default_socket_timeout to...
5 the script runs in 10
10 the script runs in 20
60 the script runs in 120
With all of the above the script still ends up showing:
Fatal error: Maximum execution time of 5 seconds exceeded in
C:\wwwroot\test\readfile\read.php on line 3
...when trying to read a file from a URL.
------------------------------------------------------------------------
[2003-02-19 19:03:34] [EMAIL PROTECTED]
Forget getting newer snapshot, just try adjusting that
php.ini directive..
------------------------------------------------------------------------
The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
http://bugs.php.net/22297
--
Edit this bug report at http://bugs.php.net/?id=22297&edit=1