dnsforward library -- consistently nullify and close listening socket when we're done with it.
This commit is contained in:
parent
639b34c7d1
commit
7944f23d95
|
@ -97,6 +97,16 @@ func (s *Server) packetLoop() {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if isConnClosed(err) {
|
if isConnClosed(err) {
|
||||||
log.Printf("ReadFrom() returned because we're reading from a closed connection, exiting loop")
|
log.Printf("ReadFrom() returned because we're reading from a closed connection, exiting loop")
|
||||||
|
var err error
|
||||||
|
s.Lock()
|
||||||
|
if s.udpListen != nil {
|
||||||
|
err = s.udpListen.Close()
|
||||||
|
s.udpListen = nil
|
||||||
|
}
|
||||||
|
s.Unlock()
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Failed to close udp connection while exiting loop: %s", err)
|
||||||
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
log.Printf("Got error when reading from udp listen: %s", err)
|
log.Printf("Got error when reading from udp listen: %s", err)
|
||||||
|
@ -124,6 +134,7 @@ func (s *Server) Start(config *ServerConfig) error {
|
||||||
}
|
}
|
||||||
s.udpListen, err = net.ListenUDP("udp", addr)
|
s.udpListen, err = net.ListenUDP("udp", addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
s.udpListen = nil
|
||||||
return errorx.Decorate(err, "Couldn't listen to UDP socket")
|
return errorx.Decorate(err, "Couldn't listen to UDP socket")
|
||||||
}
|
}
|
||||||
log.Println(s.udpListen.LocalAddr(), s.UDPListenAddr)
|
log.Println(s.udpListen.LocalAddr(), s.UDPListenAddr)
|
||||||
|
@ -144,10 +155,10 @@ func (s *Server) Stop() error {
|
||||||
defer s.Unlock()
|
defer s.Unlock()
|
||||||
if s.udpListen != nil {
|
if s.udpListen != nil {
|
||||||
err := s.udpListen.Close()
|
err := s.udpListen.Close()
|
||||||
|
s.udpListen = nil
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errorx.Decorate(err, "Couldn't close UDP listening socket")
|
return errorx.Decorate(err, "Couldn't close UDP listening socket")
|
||||||
}
|
}
|
||||||
s.udpListen = nil
|
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -188,6 +199,7 @@ func (s *Server) reconfigureListenAddr(new ServerConfig) error {
|
||||||
s.Lock()
|
s.Lock()
|
||||||
if s.udpListen != nil {
|
if s.udpListen != nil {
|
||||||
err = s.udpListen.Close()
|
err = s.udpListen.Close()
|
||||||
|
s.udpListen = nil
|
||||||
}
|
}
|
||||||
s.Unlock()
|
s.Unlock()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -198,6 +210,7 @@ func (s *Server) reconfigureListenAddr(new ServerConfig) error {
|
||||||
s.Lock()
|
s.Lock()
|
||||||
if s.udpListen != nil {
|
if s.udpListen != nil {
|
||||||
err = s.udpListen.Close()
|
err = s.udpListen.Close()
|
||||||
|
s.udpListen = nil
|
||||||
}
|
}
|
||||||
s.Unlock()
|
s.Unlock()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in New Issue