我发送了约2560封电子邮件的简报。 php脚本为表中的每封电子邮件创建一个条目,每15分钟发送50封邮件,这样服务器就不会忙碌。
当我将简报发送到所有2560封电子邮件时,我会收到404页面。当我只选择我的电子邮件时,一切都按预期进行。我认为有一些限制阻止MySQL添加那么多条目。我可以添加超过994封电子邮件,我收到404错误。我该如何解决这个问题?
我从左侧列表>中选择用户点击右箭头>当我按下提交并获得404错误(超过994时)或成功的消息时,用户被移动到右侧列表然后它们全部被选中(从“发送到”列表)。
$conn = sfContext::getInstance()->getDatabaseManager()->getDatabase('doctrine')->getDoctrineConnection();
ini_set('memory_limit', '1024M');
set_time_limit(0);
try
{
$conn->beginTransaction();
foreach ($to as $email => $name)
{
if (is_integer($email))
{
$email = $name;
}
$hash = substr(md5($email), 0, 5);
//save to cron job
$html = str_replace(array('[+hash+]', '[+email+]'),array($hash, $email), $content);
$query = $conn->prepare($sql = "INSERT INTO CronEmail (sendto_name, sendto_email, from_name, from_email, subject, message, created_at)
VALUES (:sendto_name, :sendto_email, :from_name, :from_email, :subject, :message, :created_at);");
$query->execute(
array('sendto_name' => $name,
'sendto_email' => $email,
'from_name' => "Newsletter " . $fromsite,
'from_email' => "newsletter@office.ro",
'subject' => $newsletter->getSubject(),
'message' => $html,
'created_at' => date('Y-m-d H:i:s'))
);
}
$conn->commit();
}catch (Doctrine_Exception $e) { // Rollback if transaction fail
$conn->rollback();
echo $sql;
echo $e->getMessage();
die();
}
$this->getUser()->setFlash('alert', '<div class="alert_ok">Newsletterul a fost salvat si va fi trimis!</div>');
$this->redirect('newsletter_send/index');
}
}