Unverified Commit 3eac211e authored by Steven Allen's avatar Steven Allen Committed by GitHub

Merge pull request #466 from libp2p/fix/timer-leak

fix(dialqueue): fix a timer leak
parents 4838fd5e d4818f1a
...@@ -294,6 +294,7 @@ func (dq *dialQueue) worker() { ...@@ -294,6 +294,7 @@ func (dq *dialQueue) worker() {
// This idle timer tracks if the environment is slow. If we're waiting to long to acquire a peer to dial, // This idle timer tracks if the environment is slow. If we're waiting to long to acquire a peer to dial,
// it means that the DHT query is progressing slow and we should shrink the worker pool. // it means that the DHT query is progressing slow and we should shrink the worker pool.
idleTimer := time.NewTimer(24 * time.Hour) // placeholder init value which will be overridden immediately. idleTimer := time.NewTimer(24 * time.Hour) // placeholder init value which will be overridden immediately.
defer idleTimer.Stop()
for { for {
// trap exit signals first. // trap exit signals first.
select { select {
...@@ -308,6 +309,11 @@ func (dq *dialQueue) worker() { ...@@ -308,6 +309,11 @@ func (dq *dialQueue) worker() {
select { select {
case <-idleTimer.C: case <-idleTimer.C:
default: default:
// NOTE: There is a slight race here. We could be in the
// middle of firing the timer and not read anything from the channel.
//
// However, that's not really a huge issue. We'll think
// we're idle but that's fine.
} }
idleTimer.Reset(dq.config.maxIdle) idleTimer.Reset(dq.config.maxIdle)
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment