From 2c48101a6ee1269d7c94a0c3e606b2d635b20615 Mon Sep 17 00:00:00 2001 From: Sean McArthur Date: Tue, 8 May 2018 16:32:40 -0700 Subject: [PATCH] fix(server): skip SO_REUSEPORT errors Closes #1509 --- src/server/mod.rs | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/src/server/mod.rs b/src/server/mod.rs index 8c6cd46170..3352fc5e13 100644 --- a/src/server/mod.rs +++ b/src/server/mod.rs @@ -507,19 +507,6 @@ impl Server } } -fn thread_listener(addr: &SocketAddr, handle: &Handle) -> io::Result { - let listener = match *addr { - SocketAddr::V4(_) => try!(net2::TcpBuilder::new_v4()), - SocketAddr::V6(_) => try!(net2::TcpBuilder::new_v6()), - }; - try!(reuse_port(&listener)); - try!(listener.reuse_address(true)); - try!(listener.bind(addr)); - listener.listen(1024).and_then(|l| { - TcpListener::from_listener(l, addr, handle) - }) -} - fn date_render_interval(handle: &Handle) { // Since we own the executor, we can spawn an interval to update the // thread_local rendered date, instead of checking the clock on every @@ -573,16 +560,29 @@ fn date_render_interval(handle: &Handle) { } } +fn thread_listener(addr: &SocketAddr, handle: &Handle) -> io::Result { + let listener = match *addr { + SocketAddr::V4(_) => net2::TcpBuilder::new_v4()?, + SocketAddr::V6(_) => net2::TcpBuilder::new_v6()?, + }; + reuse_port(&listener); + listener.reuse_address(true)?; + listener.bind(addr)?; + listener.listen(1024).and_then(|l| { + TcpListener::from_listener(l, addr, handle) + }) +} + #[cfg(unix)] -fn reuse_port(tcp: &net2::TcpBuilder) -> io::Result<()> { +fn reuse_port(tcp: &net2::TcpBuilder) { use net2::unix::*; - try!(tcp.reuse_port(true)); - Ok(()) + if let Err(e) = tcp.reuse_port(true) { + debug!("error setting SO_REUSEPORT: {}", e); + } } #[cfg(not(unix))] -fn reuse_port(_tcp: &net2::TcpBuilder) -> io::Result<()> { - Ok(()) +fn reuse_port(_tcp: &net2::TcpBuilder) { } impl> fmt::Debug for Server