swoole定时器莫名的自动关闭了,但是所有进程都正常运行?

1.使用swoole的tick创建了定时器,每3s去数据库查询需要发送的信息并进行发送,但是运行几天后定时器就不跑了,定时器是在启动worker进程时

function onWorkerStart(swoole_server $serv, $worker_id)
    {
        
        $this->loger->write_log('info',"Work_id " . $worker_id . " start \n");
        //如果当前运行的进程是task进程
        if($worker_id < $serv->setting['worker_num']) 
        {
            //开始执行任务
            $serv->task($worker_id);
        }     
        //添加定时器 只在第一个worker启动时创建一个定时器 来定时检索有没有要推送的消息
        if($worker_id == 0)
        {
            //创建定时器
            $timer = $serv->tick(3000,function ($timer_id){
                $db = new DBO(config_item('mall_db_config'));
                //获取所有未发送的推送消息
                $query_param = array('limit'=>100,'order'=>'createon asc','where'=>'msg_status = 0');
                $msgs = $db->select('t_msg_push',
                            array('id','mall_id','member_id','vpl','in_time','out_time','park_code',
                                'pay_points','park_duration','residual_points','msg_type'),
                            $query_param
                        );
                if(!empty($msgs))
                {
                    push_msg($msgs,$db);
                }
                else
                {
                    simple_log('No message to send.');
                }
                //关闭数据库连接
                $db->close();
            });
        }
    }
阅读 6.4k
2 个回答

是否是因为worker进程退出了?
设置了max_request,进程处理的请求数超过一定数量,会自动退出

新手上路,请多包涵

很久之前的问题了,自己也遇到了,给后来的人一些思路吧,注意是不是与客户端的连接或者是与数据库的连接被防火墙干掉了,我自己是因为只创建了一次数据库连接导致时间长了断开了,也可以考虑与客户端长时间没有数据交换导致连接被关闭的情况,这种情况可以通过发送心跳包解决

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题