Я использую PHPMailer для отправки информационного бюллетеня из списка электронных писем в базе данных. Скрипт запрашивает базу данных, помещает данные в массив с помощью цикла while, а в цикле while создает и отправляет электронное письмо.
Он работает нормально до тех пор, пока не будет отправлено 150 или около того писем, а затем случайным образом останавливается. Например, массовая рассылка электронной почты № 1 завершилась неудачей после отправки 161 электронного письма, массовая рассылка электронной почты № 2 завершилась неудачно после отправки 165 электронных писем, а массовая рассылка электронной почты № 3 завершилась неудачно после отправки 182 электронных писем.
Я исследовал и исследовал и не могу найти причину этого. Прямо сейчас я отправляю каждое электронное письмо в сообщении «Кому:» и не отправляю их с использованием маршрута BCC:. Может это настройки на моем сервере? Если да, то что я должен искать?
У меня также есть небольшая встроенная отладка. SQL-скрипт в конце добавляет электронное письмо в базу данных вместе с конкретным временем его отправки, так что я могу точно сказать, сколько отправлено, какое электронное письмо останавливает процесс, и сколько времени это занимает.
Электронные письма, на которых он останавливается, не имеют шаблона (это означает, что это разные поставщики электронной почты), и для отправки такого количества требуется всего около 10–12 минут. Тайм-аут моего сценария на сервере намного выше, так что это не причина.
Мой код выглядит следующим образом:
$mail = new PHPMailer();
$mail->IsSMTP(); // set mailer to use SMTP
$mail->Host = "*server ip here*"; // specify main and backup server
$mail->SMTPKeepAlive = true; // SMTP connection will not close after each email sent
$mail->SMTPAuth = false; // turn on SMTP authentication
$mail->Username = "*user*"; // SMTP username
$mail->Password = "*pass*"; // SMTP password
while($select2 = sqlsrv_fetch_array($select)) {
$email = $select2['email'];
$unid = $select2['id'];
$unemail = $select2['email'];
$to = $email;
$from = "[email protected]";
$new_date = date("n/j/y - g:i:s a");
$headers = "From: $from\r\n";
$headers .= "MIME-Version: 1.0\r\n";
$headers .= "Content-Type: text/html; charset=ISO-8859-1\r\n";
$message2 = "<html><body>";
$message2 .= $message;
$message2 .= "</body></html>";
$mail->From = "[email protected]";
$mail->FromName = "Newsletter";
$mail->AddAddress($to);
$mail->AddReplyTo("[email protected]", "Website.com");
$mail->IsHTML(true); // set email format to HTML
$mail->Subject = $subject;
$mail->Body = $message2;
if(!$mail->Send()) {
die("mail() Failed to send email to $to.");
echo "<br><br>Mailer Error: " . $mail->ErrorInfo;
exit;
} else {
$make_sent_query = "INSERT INTO emailssent (email_signup_id, email, datesent) VALUES (?, ?, ?)";
$params_sent = array($unid, $to, $new_date);
$add_to_sent = sqlsrv_query($conn, $make_sent_query, $params_sent);
if($add_to_sent) {
echo "Message sent for email $to<br>";
} else {
die("Mail sent, but failed to insert into Sent Emails database.");
}
}
$mail->ClearAddresses(); //clear addresses for next loop
}