Edit report at https://bugs.php.net/bug.php?id=65453&edit=1
ID: 65453 Updated by: a...@php.net Reported by: oli dot laurel at arcor dot de Summary: Readfile() + mpg = http status 500, windows server 2008 r2 sp1, php 5.5.1 Status: Feedback Type: Bug Package: IIS related Operating System: Windows Server 2008 R2 SP1 PHP Version: 5.5.1 Block user comment: N Private report: N New Comment: That's not exactly what i wanted to see because you haven't used the --server-response option with wget. But now I see what I've overseen, consider this line in your wget output: HTTP Anforderung gesendet, warte auf Antwort... 200 OK I suppose that was something like "HTTP/1.1 200 OK" in the headers. Also in your last post to see - that are not multiple downloads at the same, but restarts on connection reset. The status 500 in the logs indicates merely this, not the headers sent out. That's what i get with curl and bandwith of 20K, were probably the same with wget and this bandwidth $ curl -v --limit-rate 20k -o /dev/null http://127.0.0.1/65453/index.php * About to connect() to 127.0.0.1 port 80 (#0) * Trying 127.0.0.1... % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0connected * Connected to 127.0.0.1 (127.0.0.1) port 80 (#0) > GET /65453/index.php HTTP/1.1 > User-Agent: curl/7.21.1 (i686-pc-mingw32) libcurl/7.21.1 OpenSSL/0.9.8r > zlib/1.2.3 > Host: 127.0.0.1 > Accept: */* > < HTTP/1.1 200 OK < Cache-Control: no-cache < Content-Length: 6291456 < Content-Type: text/plain < Server: Microsoft-IIS/8.0 < X-Powered-By: PHP/5.5.2-dev < Content-Disposition: inline; filename="movie.txt" < X-Pad: avoid browser bug < Date: Tue, 20 Aug 2013 16:16:05 GMT < { [data not shown] 66 6144k 66 4095k 0 0 13525 0 0:07:45 0:05:10 0:02:35 0* Recv failure: Connection was reset 66 6144k 66 4095k 0 0 13521 0 0:07:45 0:05:10 0:02:35 0* Closing connection #0 curl: (56) Recv failure: Connection was reset Just where curl exits, wget retries the download until it's worked, so infinite tries by default. Testing with a static file works. Anyway no crash yet, but now it's to figure out why the connectio nreset happens. It could help if you could test the same with apache or cli, too. Previous Comments: ------------------------------------------------------------------------ [2013-08-20 15:31:24] oli dot laurel at arcor dot de hi, my other testsystem is windows 2012 with php 5.5.2 (x86). here is log and console output from today. same setup as above & same problem. when you cancle download of file by wget, did you get 200 or 500? C:\tmp>"C:\Program Files (x86)\GnuWin32\bin\wget.exe" --limit-rate=20000 http:// 127.0.0.1/index.php SYSTEM_WGETRC = c:/progra~1/wget/etc/wgetrc syswgetrc = C:\Program Files (x86)\GnuWin32/etc/wgetrc --2013-08-20 15:21:09-- http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 5702400 (5,4M) [text/plain] In »index.php.1« speichern. 52% [===================> ] 3.014.656 19,5K/s in 2m 31s 2013-08-20 15:23:40 (19,5 KB/s) - Lesefehler bei Byte 3014656/5702400 (Connectio n reset by peer). Erneuter Versuch. --2013-08-20 15:23:41-- (Versuch: 2) http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 5702400 (5,4M) [text/plain] In »index.php.1« speichern. 48% [=================> ] 4.193.792 --.-K/s in 4m 14s 2013-08-20 15:27:56 (16,1 KB/s) - Lesefehler bei Byte 4193792/5702400 (Connectio n reset by peer). Erneuter Versuch. --2013-08-20 15:27:58-- (Versuch: 3) http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 5702400 (5,4M) [text/plain] In »index.php.1« speichern. 42% [===============> ] 4.193.792 --.-K/s in 4m 14s 2013-08-20 15:32:13 (16,1 KB/s) - Lesefehler bei Byte 4193792/5702400 (Connectio n reset by peer). Erneuter Versuch. --2013-08-20 15:32:16-- (Versuch: 4) http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 5702400 (5,4M) [text/plain] In »index.php.1« speichern. 1% [ ] 147.456 19,5K/s eta 8m 9s ------------------------------------------------------------------------ [2013-08-20 14:43:52] oli dot laurel at arcor dot de Please try it with --limit-rate=20000: "C:\Program Files\GnuWin32\bin\wget.exe" --limit-rate=20000 http://127.0.0.1 /index.php [Console Output] ---------------- C:\>"C:\Program Files\GnuWin32\bin\wget.exe" --limit-rate=20000 http://127.0.0.1 /index.php SYSTEM_WGETRC = c:/progra~1/wget/etc/wgetrc syswgetrc = C:\Program Files\GnuWin32/etc/wgetrc --2013-08-16 09:35:00-- http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 6702080 (6,4M) [text/plain] In »index.php.7« speichern. 62% [=======================> ] 4.193.792 --.-K/s in 5m 33s 2013-08-16 09:40:35 (12,3 KB/s) - Lesefehler bei Byte 4193792/6702080 (Connectio n reset by peer). Erneuter Versuch. --2013-08-16 09:40:36-- (Versuch: 2) http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 6702080 (6,4M) [text/plain] In »index.php.7« speichern. 1% [ ] 131.072 19,5K/s eta 8m 59s ------------------------------------------------------------------------ [2013-08-20 13:15:53] a...@php.net CLI server also shows 200. It'd make sense to ask on IIS forums as well, as nothing points to PHP yet. ------------------------------------------------------------------------ [2013-08-20 12:34:12] a...@php.net I've just tried this with a text file of 6M with no reproduce. Please post the output of these commands wget --server-response --limit-rate=40000 http://127.0.0.1/65453/index.php You can also try curl. It's available for windows or with msysgit shell curl -v --limit-rate 40000 -o /dev/null http://127.0.0.1/65453/index.php Thanks ------------------------------------------------------------------------ [2013-08-16 07:45:46] oli dot laurel at arcor dot de hi, thank you for reply. - does the same happen when you out a plain text file instead of mpeg, also using appropriate content-type and --limit-rate? i changed content-type to text/plain and renamed movie.mpg to movie.txt. No behaviour change. If i abort download i will also get a 500. - does it happen when you request static content using wget with --limit-rate? no, if i just download a file for example http://127.0.0.1/movie.mpg all works fine. Also if i abort download. Please use following configuration: Description ------------ - Installed a blank Windows Server 2008 R2 SP1 Standard, added Role IIS & Feature CGI. - Extracted 5.5.1 VC11 x86 Non Thread Safe to c:\Program Files (x86)\php - Installed vcredist_x86.exe - Configuration of IIS: added Handler Mappings in IIS Request path: *.php Module: FastCgiModule Executable: c:\Program Files (x86)\php\php-cgi.exe Name: PHP via FastCgi - Then added 2 files to C:\inetpub\wwwroot index.php & movie.mpg (6MB) - add download.cmd to c: - Installed wget. - No modification of php.ini, no malware scanner, ... - start c:\download.cmd [download.cmd] -------------- "C:\Program Files\GnuWin32\bin\wget.exe" --limit-rate=20000 http://127.0.0.1/index.php [Console Output] ---------------- C:\>"C:\Program Files\GnuWin32\bin\wget.exe" --limit-rate=20000 http://127.0.0.1 /index.php SYSTEM_WGETRC = c:/progra~1/wget/etc/wgetrc syswgetrc = C:\Program Files\GnuWin32/etc/wgetrc --2013-08-16 09:35:00-- http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 6702080 (6,4M) [text/plain] In »index.php.7« speichern. 62% [=======================> ] 4.193.792 --.-K/s in 5m 33s 2013-08-16 09:40:35 (12,3 KB/s) - Lesefehler bei Byte 4193792/6702080 (Connectio n reset by peer). Erneuter Versuch. --2013-08-16 09:40:36-- (Versuch: 2) http://127.0.0.1/index.php Verbindungsaufbau zu 127.0.0.1:80... verbunden. HTTP Anforderung gesendet, warte auf Antwort... 200 OK Länge: 6702080 (6,4M) [text/plain] In »index.php.7« speichern. 1% [ ] 131.072 19,5K/s eta 8m 59s [index.php] ----------- <?php $track = "movie.txt"; if (file_exists($track)) { header("Content-Type: text/plain"); header('Content-Length: ' . filesize($track)); header('Content-Disposition: inline; filename="movie.txt"'); header('X-Pad: avoid browser bug'); header('Cache-Control: no-cache'); readfile($track); exit; } else { header($_SERVER['SERVER_PROTOCOL'].' 404 Not Found', true, 404); echo "no file"; } ?> [movie.txt] 6MB (no change if its a real movie or not) --------------- asdfghasdfghasdfgh... [w3svc1.log] ------------ #Software: Microsoft Internet Information Services 7.5 #Version: 1.0 #Date: 2013-08-16 07:38:26 #Fields: date time s-ip cs-method cs-uri-stem cs-uri-query s-port cs-username c-ip cs(User-Agent) sc-status sc-substatus sc-win32-status time-taken 2013-08-16 07:38:26 127.0.0.1 GET /index.php - 80 - 127.0.0.1 Wget/1.11.4 500 0 2147500037 205717 2013-08-16 07:41:04 127.0.0.1 GET /index.php - 80 - 127.0.0.1 Wget/1.11.4 500 0 64 28672 ------------------------------------------------------------------------ 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 https://bugs.php.net/bug.php?id=65453 -- Edit this bug report at https://bugs.php.net/bug.php?id=65453&edit=1