现象
process执行完一次后面没有动静。
在handle结束前打印,确认logger中只出现一次退出的日志,然后没有任何日志出现。
hyperfhttpserver还可以访问。
尝试
尝试1
添加
use Hyperf\Utils\Coordinator\CoordinatorManager;
use Hyperf\Utils\Coordinator\Constants;
CoordinatorManager::until(Constants::WORKER_EXIT)->resume();
没有效果
查找相关信息
[QUESTION] 自定义进程抛出异常进程无法退出重启 · Issue #2577 · hyperf/hyperf · GitHub
[QUESTION] process进程退出后没有自启 · Issue #4328 · hyperf/hyperf · GitHub
之前就有试过command无法自己退出,一定要自己干掉自己。
hyperf重启所有的自定义process进程 - Swooled
当时是类似上面这种,只不过不是用php hyperf中提供的kill方法,而是shell kill command命令做的。
但这个人感觉不是很好的办法,比较能看到WARNING Server::check_worker_exit_status(): worker(pid=xx, id=xx) abnormal exit, status=0, signal=9 ,
就知道是强制杀死了。
到底为什么会显示退出(stop)但实际上还是没有进行下一次执行呢,等待协程等什么呢?