Reputation: 1886
First a few infos:
mail()
in this case. For all my other projects I already use SMTP mailing.I have isolated the problem of a site timeout to the PHP mail()
function. This is the only line of code in a test.php file on my server:
<?php mail('[email protected]', 'test', 'test');
Which seems to take endless and is then terminated by mod_cgi after 40 seconds. The command
php -r "mail('[email protected]', 'test', 'test');"
on the command line sends the email instantly.
Please tell me which log files you want to see, the Apache log is this:
[Thu Jan 17 12:17:00 2013] [warn] [client 178.15.148.43] mod_fcgid: read data timeout in 40 seconds
[Thu Jan 17 12:17:00 2013] [error] [client 178.15.148.43] Premature end of script headers: test.php
I think the problem is that I accidentally ran chmod -R 775
on the root directory a few days ago. I fixed all errors already, besides this one.
Upvotes: 13
Views: 13145
Reputation: 5103
Do not rely on mail()
as it is unreliable and leads to issues just like these. I've used phpMailer for years quite happily.
If you persist on mail()
then check your settings in php.ini (explained at http://www.quackit.com/php/tutorial/php_mail_configuration.cfm). Note that usually CLI has a different php.ini than FastCGI.
Some more common problems:
FastCGI doesn't have permissions to use sendmail
Memory limit with large attachments
Upvotes: 2
Reputation: 2581
Most likely you use 2 different php.ini versions. one for cli and one for cgi. Debian have this setup i believe.
Make sure that your cli and cgi versions have the same email configuration and it will work.
The mail configuration key is: [mail function]
Another possibility is that your web user does't have access to execute sendmail.
Also check spool permissions (updated)
Upvotes: 7
Reputation: 2442
Do you have a problem using:
exec('php -r \"mail('[email protected]', 'test', 'test');\"');
Upvotes: 0
Reputation: 106
I've been searching for this particular error and have found that it can be caused by a variety of things. I do not know what you have already tried to do to fix it, but here are some suggestions as to what might help:
<?php
and end with ?>
There's also another question about this subject here on SO: PHP Mail Function Causes Error - The owner stated that a change of server with the same setup resulted in a working mail() function, which could indicate a problem with the host.
Upvotes: 0
Reputation: 4940
Is it possible that you have a firewall blocking outgoing SMTP connections? Are there other things on that server that can successfully send email?
I would make this a comment, but am not allowed to yet.
Upvotes: 0