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] [email protected]
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] [email protected]
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] [email protected]
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