最长执行时间超过60秒

问题描述 投票:0回答:1

我有几张要使用Twilio发送到WhatsApp编号的图像。我只想在发送完所有图像后再发送一条短信。发送图像时,我指定了一个回调,该回调获取传送状态并使用Redis进行存储。打电话发送这些图像后,我检查所有图像的传送状态,如果所有图像的状态都不等于零,则发送文本消息,否则我进行检查,直到得到一个交货状态不为零。但是,我提出的解决方案正在超时。我收到此错误-Maximum execution time of 60 seconds exceeded from Redis即使图像未发送。见所附图片enter image description here

这是我在做什么:

Route::get('test', function (){
    $redis = new \Predis\Client();
    $images = \App\ProductImage::where('product_id', 7)->get();

    foreach ($images as$image){
        $imgUrl = url(env('BOT_URL').'/images/'.$image['img_url']);
        $sid[] = \App\Libraries\Utilities::sendMediaMessage('+23xxxxx', '', $imgUrl);
    }
    foreach ($sid as $id){
        $statuses[] = $redis->get($id);
    }

    if(in_array(0, $statuses)){
           $check = \App\Libraries\Utilities::checkIfWhatsAppStatusHasChanged($sid);
        if ($check){
            \App\Libraries\Utilities::sendWhatsAppMessage('+23xxxxx', 'Send message - had to check');
        }
    }else{
        \App\Libraries\Utilities::sendWhatsAppMessage('+23xxxx', 'Send message ');
    }

});

这里是sendMediaMessage方法

 public static function sendMediaMessage($phone, $msg, $mediaUrl){
             try{

            $client = new Client(env('TWILIO_SID'), env('TWILIO_TOKEN'));
            $send = $client->messages->create(
                "whatsapp:".$phone, // Text this number
                array(
                    'from' => "whatsapp:".env('TWILIO_NUMBER'), // From a valid Twilio number
                    'body' => $msg,
                    'mediaUrl' => $mediaUrl,
                    'statusCallback' => url(env('BOT_URL').'/whatsapp-delivery-status')
                )
            );
            //
            if($send != false){
                $message_sid = $send->sid;
                return $message_sid;
            }

        }catch (\Exception $exception){
        }
    }

这里是回调方法-

   public function checkWhatsapDelivery(Request $request)
    {
        $redis = new Client();
        $body = $request->all();
        $messageSid = $body['MessageSid'];
        $MessageStatus = $body['MessageStatus'];
        $status_id = Utilities::getWhatsappMessageStatus($MessageStatus);
        $redis->set($messageSid, $status_id);
    }

这里是getWhatsappMessageStatus方法

 public static function getWhatsappMessageStatus($status){
        switch (strtolower($status)){
            case 'queued':
                $id = 1;
                break;
            case 'failed':
                $id = 2;
                break;
            case 'sent':
                $id = 3;
                break;
            case 'delivered':
                $id = 4;
                break;
            case 'read':
                $id = 5;
                break;
            default:
                $id = 0;
        }
        return $id;
    }

这里是checkIfWhatsAppStatusHasChanged方法

  public static function checkIfWhatsAppStatusHasChanged($sids){
        $statuses = self::getWhatsAppStatuses($sids);
        if(in_array(0, $statuses)){
            self::checkIfWhatsAppStatusHasChanged($sids);
        }else{
            return true;
        }
    }

这里是getWhatsAppStatuses方法

public static function getWhatsAppStatuses($sids){
        $redis = new \Predis\Client();
        foreach ($sids as $id){
            $statuses[] = $redis->get($id);
        }
        return $statuses;
}

请问我做错了什么?

php laravel redis twilio-api
1个回答
0
投票

检查Linux中php.ini(windows)和C:\xampp\php\php.ini中的opt/lampp/etc/php.ini文件。默认情况下,这是max_execution_time = 60秒。因此,您必须增加max_execution_time才能发送/发布大尺寸数据。

© www.soinside.com 2019 - 2024. All rights reserved.