From 429ad8a34b20a877b4d17df1f4991a193f4a56f0 Mon Sep 17 00:00:00 2001 From: Hu# Date: Thu, 2 Nov 2023 20:04:33 +0800 Subject: [PATCH] fix(http2): don't send keep-alive ping when idle (#3381) Signed-off-by: husharp --- src/proto/h2/ping.rs | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/proto/h2/ping.rs b/src/proto/h2/ping.rs index 61d24112f6..ea2bbb36ad 100644 --- a/src/proto/h2/ping.rs +++ b/src/proto/h2/ping.rs @@ -264,7 +264,7 @@ impl Ponger { if let Some(ref mut ka) = self.keep_alive { ka.maybe_schedule(is_idle, &locked); - ka.maybe_ping(cx, &mut locked); + ka.maybe_ping(cx, is_idle, &mut locked); } if !locked.is_ping_sent() { @@ -284,7 +284,7 @@ impl Ponger { if let Some(ref mut ka) = self.keep_alive { locked.update_last_read_at(); ka.maybe_schedule(is_idle, &locked); - ka.maybe_ping(cx, &mut locked); + ka.maybe_ping(cx, is_idle, &mut locked); } if let Some(ref mut bdp) = self.bdp { @@ -448,7 +448,7 @@ impl KeepAlive { self.timer.reset(&mut self.sleep, interval); } - fn maybe_ping(&mut self, cx: &mut task::Context<'_>, shared: &mut Shared) { + fn maybe_ping(&mut self, cx: &mut task::Context<'_>, is_idle: bool, shared: &mut Shared) { match self.state { KeepAliveState::Scheduled(at) => { if Pin::new(&mut self.sleep).poll(cx).is_pending() { @@ -460,6 +460,10 @@ impl KeepAlive { cx.waker().wake_by_ref(); // schedule us again return; } + if !self.while_idle && is_idle { + trace!("keep-alive no need to ping when idle and while_idle=false"); + return; + } trace!("keep-alive interval ({:?}) reached", self.interval); shared.send_ping(); self.state = KeepAliveState::PingSent;