Я получаю сообщение об ошибке HTTP 500 на своей работе cron, пока она отправляет электронную почту в цикле, используя класс электронной почты в ci3 - PullRequest
0 голосов
/ 03 мая 2019

У меня есть задание cron, которое отправляет электронную почту подписчикам, используя класс электронной почты CodeIgniter 3. Я использовал SMTP почтовый сервис, предоставленный хостом. Задание cron выдает ошибку HTTP 500 после 2-3 минут работы и отправки 453 электронных писем. Я использовал сон после отправки 400 писем. Количество писем, отправляемых сервером, не ограничено. Пожалуйста, ознакомьтесь с кодом ниже.

    <?php $sn=1;$emailCount=0;
    $config = array(
          'protocol'  => 'smtp',
          'smtp_host' => 'smtp.something.com',
          'smtp_port' => 587,
          'smtp_user' => 'something@some.com',
          'smtp_pass' => 'somepass',
          'mailtype'  => 'html',
          'charset'   => 'utf-8',
          'smtp_crypto' => 'tls'
     );
     $this->email->initialize($config);
     log_message("info", "Email Cron job started");
     foreach($member as $row){ 

        $this->email->clear();
        $this->email->set_mailtype("html");
        $this->email->set_newline("\r\n");
        $this->email->from('something@some.com','Sm');
        $this->email->subject($title);
        $this->email->set_header('Header1', 'MIME-Version: 2.5.6');
        $this->email->to(trim($row->email_address));

        ob_start();
        ?>
        <table  border="0" cellpadding="0" cellspacing="0" width="100%">
        <tbody>
        <tr><td height="15">&nbsp;</td></tr>
        <!-- many lines of code just html-->
        <tr><td height="15">&nbsp;</td></tr>
        </tbody>
        </table>
        <?php
        $message = ob_get_contents();
        ob_clean();
        ob_flush();
        $this->email->message($message);
        if($emailCount % 400 == 0 && $emailCount != 0)
        {
           sleep(15);
           log_message("info", "Sleep.Emails Sent: ".$emailCount); 
        }
        if($this->email->send())
        {
           $emailCount++;    
        }
        else
        {
           log_message("info", "Error! Total Emails Sent: ".$emailCount);
        }
        $sn++;
     } 
     log_message("info", "Total Emails Sent: ".$emailCount);
     log_message("info", "Total Loop Ran: ".$sn);?>  

Пробовал спать (), но не работал.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...