在我正在使用的当前项目中,我有一个symfony任务,它将一些海量数据插入数据库并运行至少半小时。 当任务开始正确发送邮件通知时,问题是在执行任务时我们无法发送另一封邮件来通知处理结束。
邮件工厂当前配置了假脱机传送策略,但在这种特定情况下,我们希望使用sendNextImmediately()方法立即触发通知。
我正在接受例外:
[Swift_TransportException]
预期的响应代码250但得到代码“451”,消息“451 4.4.2超时 - 关闭连接.74sm1186065wem.17 “
和php日志文件中的流动错误:
警告:fwrite():SSL:第209行/var/www/project/lib/vendor/symfony/lib/vendor/swiftmailer/classes/Swift/Transport/StreamBuffer.php中的管道损坏
有人能帮忙吗? 有什么方法可以刷新symfony邮件程序来建立新连接吗?
答案 0 :(得分:5)
做一个Symfony2项目,我也遇到了这个失败。我们使用永久运行的php脚本,产生错误。
我们发现以下代码完成了这项工作:
private function sendEmailMessage($renderedTemplate, $subject, $toEmail)
{
$mailer = $this->getContainer()->get('mailer');
/* @var $mailer \Swift_Mailer */
if(!$mailer->getTransport()->isStarted()){
$mailer->getTransport()->start();
}
$sendException = null;
/* @var $message \Swift_Message */
$message = \Swift_Message::newInstance()
->setSubject($subject)
->setFrom($this->getContainer()->getParameter('email_from'))
->setTo($toEmail)
->setBody($renderedTemplate);
$mailer->send($message);
$mailer->getTransport()->stop();
//throw $sendException;
}
答案 1 :(得分:1)
我的猜测是连接持续时间太长(根本没有活动),导致ssl连接超时。
目前,问题可以通过在发送第二条消息之前停止Swift_Transport
实例并再次显式启动来解决。
以下是代码:
$this->getMailer()->getRealtimeTransport()->stop();
$this->getMailer()->getRealtimeTransport()->start();
$this->getMailer()->sendNextImmediately()->send($message);
答案 2 :(得分:0)
我有完全相同的问题,上面的解决方案非常有用,但有一件事我必须采取不同的做法:订购。
$this->getMailer()->sendNextImmediately()->send($message);
$this->getMailer()->getRealtimeTransport()->stop();
如果我在发送消息之前尝试停止传输(连接超时已经挂起),那对我没用。此外,您不需要运行getRealtimeTransport() - > start() - 它将自动启动。