执行60秒后Webhook遇到“Read timeout expired”错误

时间:2017-07-06 13:26:05

标签: php timeout telegram-webhook

最近我遇到了电报bot api的问题我之前没有过...我使用Webhook连接方法捕获机器人请求并使用PHP脚本重新编码,有时触发的脚本需要一分多钟才能完成处理。大约一个月前一切都工作正常,电报机器人等待足够长的时间让脚本完全执行,但现在我的连接暂停,我通过电报api获取此Webhook错误“读取超时已过期”60秒后执行,然后尝试相同再次请求,这些继续,直到我的服务器超载太多开放条目...我已经尝试connection-handling虽然它似乎没用,因为我的连接不是浏览器端。我意识到它应该与Webhook的设置本身有关但我无法弄明白......任何想法?

这可以给你一个数字:

我的代码:

<?php

...running hundreds of thousands of multi-curl requests that take 10 min for example
...or/ sleep(61);
...or/ basically anything that takes more than 60 seconds to run

?>

Telegram在运行上述脚本60秒后对我的Webhook状态的响应:

  

{ “OK”:真, “结果”:{ “URL”: “https://????.com/??.php”, “has_custom_certificate”:假 “pending_update_count”:1, “last_error_date”:1499351442, “last_error_message”:”读取超时已到期“,”max_connections“:40}}

2 个答案:

答案 0 :(得分:0)

这是我放在脚本顶部的代码。它响应电报,所以他们停止等待,脚本继续处理。

<?php
    set_time_limit(0);
    ignore_user_abort(true);
    $out =  json_encode([
      'method'=>'sendMessage',
      'chat_id'=>$my_chat_id,
      'text'=> "Starting process..."
      ]);   
    echo $out;
    header('Connection: close');
    header('Content-Length: '.strlen($out));
    header("Content-type:application/json");
    flush();
    if (function_exists('fastcgi_finish_request')) {
        fastcgi_finish_request();
    }

答案 1 :(得分:0)

将此代码放在更新变量之后:

<?php
    $update = json_decode(file_get_contents('php://input'));
       if(isset($update->message) || isset($update->edited_message)) {
                if(time()-((@$update->message->date)?:(@$update->edited_message->date)) > 59) {
           /* print json update*/   exit('Update Time Out !');
                }
            }

注意:当然,您也可以获取更新以接收Json并找出发出了哪个超时请求。

注意:如果接收源更新的方法与我的不同,请根据您的源进行更改。

注意:如果您知道脚本要花费一分钟以上的时间,那么这对您不起作用。