mirror of
https://gitlab.com/veilid/veilid.git
synced 2025-01-26 06:26:05 -05:00
re-enable SO_LINGER(0)
This commit is contained in:
parent
e568c39efb
commit
39d8b397fa
@ -132,33 +132,33 @@ impl Network {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// #[cfg(all(feature = "rt-async-std", unix))]
|
#[cfg(all(feature = "rt-async-std", unix))]
|
||||||
// {
|
{
|
||||||
// // async-std does not directly support linger on TcpStream yet
|
// async-std does not directly support linger on TcpStream yet
|
||||||
// use std::os::fd::{AsRawFd, FromRawFd};
|
use std::os::fd::{AsRawFd, FromRawFd};
|
||||||
// if let Err(e) = unsafe { socket2::Socket::from_raw_fd(tcp_stream.as_raw_fd()) }
|
if let Err(e) = unsafe { socket2::Socket::from_raw_fd(tcp_stream.as_raw_fd()) }
|
||||||
// .set_linger(Some(core::time::Duration::from_secs(0)))
|
.set_linger(Some(core::time::Duration::from_secs(0)))
|
||||||
// {
|
{
|
||||||
// log_net!(debug "Couldn't set TCP linger: {}", e);
|
log_net!(debug "Couldn't set TCP linger: {}", e);
|
||||||
// return;
|
return;
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// #[cfg(all(feature = "rt-async-std", windows))]
|
#[cfg(all(feature = "rt-async-std", windows))]
|
||||||
// {
|
{
|
||||||
// // async-std does not directly support linger on TcpStream yet
|
// async-std does not directly support linger on TcpStream yet
|
||||||
// use std::os::windows::io::{AsRawSocket, FromRawSocket};
|
use std::os::windows::io::{AsRawSocket, FromRawSocket};
|
||||||
// if let Err(e) = unsafe { socket2::Socket::from_raw_socket(tcp_stream.as_raw_socket()) }
|
if let Err(e) = unsafe { socket2::Socket::from_raw_socket(tcp_stream.as_raw_socket()) }
|
||||||
// .set_linger(Some(core::time::Duration::from_secs(0)))
|
.set_linger(Some(core::time::Duration::from_secs(0)))
|
||||||
// {
|
{
|
||||||
// log_net!(debug "Couldn't set TCP linger: {}", e);
|
log_net!(debug "Couldn't set TCP linger: {}", e);
|
||||||
// return;
|
return;
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// #[cfg(not(feature = "rt-async-std"))]
|
#[cfg(not(feature = "rt-async-std"))]
|
||||||
// if let Err(e) = tcp_stream.set_linger(Some(core::time::Duration::from_secs(0))) {
|
if let Err(e) = tcp_stream.set_linger(Some(core::time::Duration::from_secs(0))) {
|
||||||
// log_net!(debug "Couldn't set TCP linger: {}", e);
|
log_net!(debug "Couldn't set TCP linger: {}", e);
|
||||||
// return;
|
return;
|
||||||
// }
|
}
|
||||||
if let Err(e) = tcp_stream.set_nodelay(true) {
|
if let Err(e) = tcp_stream.set_nodelay(true) {
|
||||||
log_net!(debug "Couldn't set TCP nodelay: {}", e);
|
log_net!(debug "Couldn't set TCP nodelay: {}", e);
|
||||||
return;
|
return;
|
||||||
|
@ -91,9 +91,9 @@ pub fn new_default_tcp_socket(domain: Domain) -> io::Result<Socket> {
|
|||||||
#[instrument(level = "trace", ret)]
|
#[instrument(level = "trace", ret)]
|
||||||
pub fn new_shared_tcp_socket(domain: Domain) -> io::Result<Socket> {
|
pub fn new_shared_tcp_socket(domain: Domain) -> io::Result<Socket> {
|
||||||
let socket = Socket::new(domain, Type::STREAM, Some(Protocol::TCP))?;
|
let socket = Socket::new(domain, Type::STREAM, Some(Protocol::TCP))?;
|
||||||
// if let Err(e) = socket.set_linger(Some(core::time::Duration::from_secs(0))) {
|
if let Err(e) = socket.set_linger(Some(core::time::Duration::from_secs(0))) {
|
||||||
// log_net!(error "Couldn't set TCP linger: {}", e);
|
log_net!(error "Couldn't set TCP linger: {}", e);
|
||||||
// }
|
}
|
||||||
if let Err(e) = socket.set_nodelay(true) {
|
if let Err(e) = socket.set_nodelay(true) {
|
||||||
log_net!(error "Couldn't set TCP nodelay: {}", e);
|
log_net!(error "Couldn't set TCP nodelay: {}", e);
|
||||||
}
|
}
|
||||||
|
@ -265,7 +265,7 @@ impl NetworkConnection {
|
|||||||
|
|
||||||
// Connection receiver loop
|
// Connection receiver loop
|
||||||
#[allow(clippy::too_many_arguments)]
|
#[allow(clippy::too_many_arguments)]
|
||||||
//#[instrument(level="trace", target="net", skip_all)]
|
#[instrument(level="trace", target="net", skip_all)]
|
||||||
fn process_connection(
|
fn process_connection(
|
||||||
connection_manager: ConnectionManager,
|
connection_manager: ConnectionManager,
|
||||||
local_stop_token: StopToken,
|
local_stop_token: StopToken,
|
||||||
@ -299,7 +299,7 @@ impl NetworkConnection {
|
|||||||
};
|
};
|
||||||
let timer = MutableFuture::new(new_timer());
|
let timer = MutableFuture::new(new_timer());
|
||||||
|
|
||||||
unord.push(system_boxed(timer.clone().in_current_span()));
|
unord.push(system_boxed(timer.clone()));
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
// Add another message sender future if necessary
|
// Add another message sender future if necessary
|
||||||
|
Loading…
x
Reference in New Issue
Block a user