From 80456b48673a0adb5eb2dd082b8b455b3c1a9522 Mon Sep 17 00:00:00 2001 From: PioLing <964472638@qq.com> Date: Tue, 6 Aug 2024 11:22:10 +0800 Subject: [PATCH] Fix the EventPoller exit exception. (ZLMediakit #3789) --- src/Poller/EventPoller.cpp | 34 ++++++++++++++++++---------------- src/Poller/EventPoller.h | 2 +- 2 files changed, 19 insertions(+), 17 deletions(-) diff --git a/src/Poller/EventPoller.cpp b/src/Poller/EventPoller.cpp index b0bfba72..d568baa3 100644 --- a/src/Poller/EventPoller.cpp +++ b/src/Poller/EventPoller.cpp @@ -104,7 +104,7 @@ EventPoller::~EventPoller() { #endif //退出前清理管道中的数据 - onPipeEvent(); + onPipeEvent(true); InfoL << getThreadName(); } @@ -276,23 +276,25 @@ bool EventPoller::isCurrentThread() { return !_loop_thread || _loop_thread->get_id() == this_thread::get_id(); } -inline void EventPoller::onPipeEvent() { +inline void EventPoller::onPipeEvent(bool flus) { char buf[1024]; int err = 0; - while (true) { - if ((err = _pipe.read(buf, sizeof(buf))) > 0) { - // 读到管道数据,继续读,直到读空为止 - continue; - } - if (err == 0 || get_uv_error(true) != UV_EAGAIN) { - // 收到eof或非EAGAIN(无更多数据)错误,说明管道无效了,重新打开管道 - ErrorL << "Invalid pipe fd of event poller, reopen it"; - delEvent(_pipe.readFD()); - _pipe.reOpen(); - addEventPipe(); - } - break; - } + if (!flus) { + for (;;) { + if ((err = _pipe.read(buf, sizeof(buf))) > 0) { + // 读到管道数据,继续读,直到读空为止 + continue; + } + if (err == 0 || get_uv_error(true) != UV_EAGAIN) { + // 收到eof或非EAGAIN(无更多数据)错误,说明管道无效了,重新打开管道 + ErrorL << "Invalid pipe fd of event poller, reopen it"; + delEvent(_pipe.readFD()); + _pipe.reOpen(); + addEventPipe(); + } + break; + } + } decltype(_list_task) _list_swap; { diff --git a/src/Poller/EventPoller.h b/src/Poller/EventPoller.h index 3676bed7..4fb45026 100644 --- a/src/Poller/EventPoller.h +++ b/src/Poller/EventPoller.h @@ -152,7 +152,7 @@ class EventPoller : public TaskExecutor, public AnyStorage, public std::enable_s /** * 内部管道事件,用于唤醒轮询线程用 */ - void onPipeEvent(); + void onPipeEvent(bool flus = false); /** * 切换线程并执行任务