mirror of
https://github.com/feschber/lan-mouse.git
synced 2026-03-07 20:09:59 +03:00
improve reliability of connections (#349)
This commit is contained in:
committed by
GitHub
parent
bdafaa07e5
commit
640fa995a4
@@ -223,14 +223,18 @@ async fn ping_pong(
|
|||||||
) {
|
) {
|
||||||
loop {
|
loop {
|
||||||
let (buf, len) = ProtoEvent::Ping.into();
|
let (buf, len) = ProtoEvent::Ping.into();
|
||||||
if let Err(e) = conn.send(&buf[..len]).await {
|
|
||||||
log::warn!("{addr}: send error `{e}`, closing connection");
|
|
||||||
let _ = conn.close().await;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
log::trace!("PING >->->->->- {addr}");
|
|
||||||
|
|
||||||
tokio::time::sleep(Duration::from_millis(500)).await;
|
// send 4 pings, at least one must be answered
|
||||||
|
for _ in 0..4 {
|
||||||
|
if let Err(e) = conn.send(&buf[..len]).await {
|
||||||
|
log::warn!("{addr}: send error `{e}`, closing connection");
|
||||||
|
let _ = conn.close().await;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
log::trace!("PING >->->->->- {addr}");
|
||||||
|
|
||||||
|
tokio::time::sleep(Duration::from_millis(500)).await;
|
||||||
|
}
|
||||||
|
|
||||||
if !ping_response.borrow_mut().remove(&addr) {
|
if !ping_response.borrow_mut().remove(&addr) {
|
||||||
log::warn!("{addr} did not respond, closing connection");
|
log::warn!("{addr} did not respond, closing connection");
|
||||||
|
|||||||
Reference in New Issue
Block a user