consul: ensure conn pool shutdown is fast

pull/19/head
Armon Dadgar 2014-02-05 14:20:18 -08:00
parent e173e7eeff
commit 18b4e51bb5
1 changed files with 16 additions and 6 deletions

View File

@ -39,7 +39,8 @@ type ConnPool struct {
pool map[string][]*Conn
// Used to indicate the pool is shutdown
shutdown bool
shutdown bool
shutdownCh chan struct{}
}
// NewPool is used to make a new connection pool
@ -47,9 +48,10 @@ type ConnPool struct {
// Set maxTime to 0 to disable reaping.
func NewPool(maxConns int, maxTime time.Duration) *ConnPool {
pool := &ConnPool{
maxConns: maxConns,
maxTime: maxTime,
pool: make(map[string][]*Conn),
maxConns: maxConns,
maxTime: maxTime,
pool: make(map[string][]*Conn),
shutdownCh: make(chan struct{}),
}
if maxTime > 0 {
go pool.reap()
@ -68,8 +70,12 @@ func (p *ConnPool) Shutdown() error {
}
}
p.pool = make(map[string][]*Conn)
p.shutdown = true
if p.shutdown {
return nil
}
p.shutdown = true
close(p.shutdownCh)
return nil
}
@ -187,7 +193,11 @@ func (p *ConnPool) RPC(addr net.Addr, method string, args interface{}, reply int
func (p *ConnPool) reap() {
for !p.shutdown {
// Sleep for a while
time.Sleep(time.Second)
select {
case <-time.After(time.Second):
case <-p.shutdownCh:
return
}
// Reap all old conns
p.Lock()