4

在我目前正在工作的当前项目中,我有一个 symfony 任务,它运行一些大量数据插入数据库并运行至少半小时。当任务开始时,邮件通知被正确发送,问题是在任务执行时我们不能发送另一封邮件来通知处理结束。

邮件工厂当前配置了假脱机传递策略,但在这种特定情况下,我们希望使用 sendNextImmediately() 方法立即触发通知。

我得到了例外:

[Swift_TransportException]
预期响应代码 250,但得到代码“451”,消息“451 4.4.2 超时 - 关闭连接。74sm1186065wem.17”

以及 php 日志文件中的流动错误:

警告:fwrite(): SSL: Broken pipe in /var/www/project/lib/vendor/symfony/lib/vendor/swiftmailer/classes/Swift/Transport/StreamBuffer.php 在第 209 行

任何人都可以提供一些帮助吗?有什么方法可以刷新 symfony 邮件程序以建立新连接?

4

3 回答 3

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;
    }
于 2011-11-07T09:45:17.513 回答
1

对于 Symfony1 用户

我的猜测是连接被保持太久(根本没有活动),导致 ssl 连接超时。

目前,可以通过Swift_Transport在发送第二条消息之前停止实例并显式重新启动它来解决问题。

这是代码:

$this->getMailer()->getRealtimeTransport()->stop();
$this->getMailer()->getRealtimeTransport()->start();
$this->getMailer()->sendNextImmediately()->send($message);
于 2011-07-04T11:16:43.347 回答
0

我遇到了完全相同的问题,上述解决方案非常有帮助,但是我必须做不同的一件事:订购。

$this->getMailer()->sendNextImmediately()->send($message);
$this->getMailer()->getRealtimeTransport()->stop();

如果我在发送消息之前尝试停止传输(连接超时已经挂起),它对我不起作用。此外,您不需要运行 getRealtimeTransport()->start() - 它会自动启动。

于 2012-08-24T11:49:47.313 回答