Symfony邮件程序:消息发送之间的Swift_TransportException

时间:2011-07-01 15:12:52

标签: symfony1 swiftmailer

在我正在使用的当前项目中,我有一个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邮件程序来建立新连接吗?

3 个答案:

答案 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)

对于Symfony1用户

我的猜测是连接持续时间太长(根本没有活动),导致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() - 它将自动启动。