几个月前,我在考虑如何在Go中为RPC库实现可关闭的事件循环。我设法方便地关闭服务器,如下所示:
type Server struct {
listener net.Listener
closeChan chan bool
routines sync.WaitGroup
}
func (s *Server) Serve() {
s.routines.Add(1)
defer s.routines.Done()
defer s.listener.Close()
for {
select {
case <-s.closeChan:
// close server etc.
default:
s.listener.SetDeadline(time.Now().Add(2 * time.Second))
conn, _ := s.listener.Accept()
// handle conn routine
}
}
}
func (s *Server) Close() {
s.closeChan <- true // signal to close serve routine
s.routines.Wait()
}
我发现此实现的问题在于它涉及超时,这意味着最小关闭时间比可能的要多2秒。有没有更惯用的方法来创建事件循环?
波斯汪
相关分类