Edit report at https://bugs.php.net/bug.php?id=65453&edit=1
ID: 65453 Comment by: oli dot laurel at arcor dot de 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: 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 Previous Comments: ------------------------------------------------------------------------ [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 ------------------------------------------------------------------------ [2013-08-15 16:21:36] a...@php.net This looks like server misconfig at first glance. In the BT there is nothing about PHP. Combined with the fact you find nothing in the error log, it might be not PHP. How did you get that BT? Debug symbols should be used for PHP as well. And when IIS starts, you should attach the debugger to the clean PHP fcgi process, so then debugger takes over. Some more points before i go try it - does the same happen when you out a plain text file instead of mpeg, also using appropriate content- type and --limit-rate? - does it happen when you request static content using wget with --limit-rate? - please post the request/response headers Thanks. ------------------------------------------------------------------------ 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