ID:               39507
 Comment by:       php at shitware dot nl
 Reported By:      rherror404 at gmail dot com
 Status:           Open
 Bug Type:         Feature/Change Request
 Operating System: Windows
 PHP Version:      5.2.0
 New Comment:

I have a simple test script sending out an e-mail message at exactly
the same time. One sends to r...@work.com, other to r...@home.com.
'Sometimes' the two get mixed up completely. This is what I received 'at
home':


Date: Thu, 09 Jul 2009 17:48:00 +0200
Subject: parallel test
From: r...@work.org
MIME-Version: 1.0
Content-Type: multipart/mixed;
boundary="==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx"
To: r...@work.com

--==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx
Content-Type: text/plain; charset=utf-8
Content-Transfer-Encoding: 7bit

parallel test

--==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx
Content-ID: 91ca2796c5b3542ce33422e15c31414d
Content-Type: application/pdf; name="test.pdf"
Content-Transfer-Encoding: base64

JVBERi0xLjMNJeLjz9MNCjcxOCAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAxNzA1NzMvTyA3MjAv
RSAzMTEzNy9OIDYvVCAxNTYxNjUvSCBbIDkzNCAzMTddPj4NZW5kb2JqDSAgICAgICAgICAgICAg
//snip snip -- up until the next 2.5 lines is only part of the
attachment
//see where the new 'header' starts ...
YmoNNzMyIDAgb2JqDTw8L0xlbmd0aCA3NDYvRmlsdGVyL0ZsYXRlRGVjb2RlPj5zdHJlYW0NCkiJ
zFdNj9MwEL33V/gPbOoZexxbqiy1aSqBtCdyQwit+DggQBwWiZ/PxB+xs6Vs8fbAwUrsODOTN+/N
OLvTeDpJidJ7Lw7HQWx2UkLvpy+b8Z5n2ElyQorp4+YtP1FWSqN57D1InpDate: Thu, 09
Jul 2009 17:48:00 +0200
Subject: parallel test to r...@home.com at 17:48:00
From: r...@work.com
MIME-Version: 1.0
Content-Type: multipart/mixed;
boundary="==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx"
To: r...@home.com

--==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx
Content-Type: text/plain; charset=utf-8
Content-Transfer-Encoding: 7bit

parallel test

--==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx
Content-ID: 91ca2796c5b3542ce33422e15c31414d
Content-Type: application/pdf; name="test.pdf"
Content-Transfer-Encoding: base64

JVBERi0xLjMNJeLjz9MNCjcxOCAwIG9iag08PC9MaW5lYXJpemVkIDEvTCAxNzA1NzMvTyA3MjAv
RSAzMTEzNy9OIDYvVCAxNTYxNjUvSCBbIDkzNCAzMTddPj4NZW5kb2JqDSAgICAgICAgICAgICAg
//snip snip -- full PDF
MDAwMDAwMDAwIDY1NTM1IGYNCjAwMDAwMDAwMDAgNjU1MzUgZg0KdHJhaWxlcg0KPDwvU2l6ZSA3
MTg+Pg0Kc3RhcnR4cmVmDQoxMTYNCiUlRU9GDQo=


--==Multipart_Boundary_x0a08807ab511e1f5db827a961c83fe3cx--


We have this same problem on a production site (WAMP) where 'sometimes'
e-mail messages and/or attachments end up in 'the wrong place'.

In short: no, the mail() function is not thread-safe!


Previous Comments:
------------------------------------------------------------------------

[2007-01-07 05:41:31] rherror404 at gmail dot com

> It sounds like SMTP server flood
> limiter is being triggered 
> here. Not a PHP issue.
Nice try, but it is a PHP issue, at least under Apache on win32.  I
only tried sending only just a few messages at a time.  My earlier
remark about "serious volumes" isn't what this bug report is about, it's
about being able to send MORE THAN JUST ONE at a time without it
stumbling all over itself.  My testing used EXACTLY TWO concurrent
attempts.  Please re-read my remarks about execution under the Apache
WinNT MPM.

Is the mail() function thread-safe?

------------------------------------------------------------------------

[2007-01-07 05:01:48] il...@php.net

Sorry, but your problem does not imply a bug in PHP itself.  For a
list of more appropriate places to ask for help using PHP, please
visit http://www.php.net/support.php as this bug system is not the
appropriate forum for asking support questions.  Due to the volume
of reports we can not explain in detail here why your report is not
a bug.  The support channels will be able to provide an explanation
for you.

Thank you for your interest in PHP.

It sounds like SMTP server flood limiter is being triggered 
here. Not a PHP issue.

------------------------------------------------------------------------

[2006-11-20 19:42:15] rherror404 at gmail dot com

I have found a work-around (not a fix).

Do not rely upon the current mail() (at least under the Apache WinNT
MPM) to be of any use for the case where more than one mod_php script is
forwarding a message to an SMTP relay host.

Have the mod_php script spawn a child process that takes a bit of
serialized state via its STDIN and let the new process do the mail()
work.  See the proc_open() docs.

If you have serious volumes of mail to send, either do it from a Linux
box or find some other way to do it from your Windows box.  Calling
mail() under Windows/Apache/PHP for anything close to that (as it
stands) is not advisable.

------------------------------------------------------------------------

[2006-11-14 16:14:10] rherror404 at gmail dot com

I suspect this may be the same bug mentioned in #31676.  My best guess
is that this is related to multi-threading.

------------------------------------------------------------------------

[2006-11-14 04:18:49] rherror404 at gmail dot com

<?
/*
Here it is again, edited slightly
to run on a Linux machine so that
it has its local sendmail do the work.
Concurrent requests to the script were
handled quite nicely.  The huge difference
in this case is the Apache prefork MPM.
*/
define('EXTRAHEADERS', "MIME-Version: 1.0\r\nContent-type: text/html;
charset=iso-8859-1\r\nX-Mailer: PHP\r\n");
define('MAILMSG',
"<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\">
<html><head><title>foo</title><style type='text/css'>
body {margin: 0; font-size: 10pt; font-family: sans-serif, arial;
color: #000000; background-color: #ffffff;}
</style></head><body><div style='font-size: 12pt; background-color:
#ffff00;'>" . date("Y-m-d H:i:s") . "</div>
random junk<br />" .
str_repeat("afhlkhsad;lfj;lkjsa;lfjasd;lkjf;lkjsad;lkfjsad;lkfjsad;lkfja
sd;lfkjasd;lkfjsa;ldf<br />\n", 100) .
"</body></html>");
ini_set('html_errors', FALSE);
define('MAILTO', 'someth...@thatworks.com'); // something real
$retval = mail(MAILTO, 'foo', MAILMSG, EXTRAHEADERS);
echo ( $retval ? 'TRUE' : 'FALSE' ) . "\n\n\n";
exit();
?>

------------------------------------------------------------------------

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/39507

-- 
Edit this bug report at http://bugs.php.net/?id=39507&edit=1

Reply via email to