From b4e284f301d6c0f62a619bc4d94d45dad71b6b45 Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Thu, 12 Sep 2019 16:47:08 +0300 Subject: [PATCH] discovery: make pool management more reliable Just drop excessive addresses, otherwise we can block for no good reason. --- pkg/network/discovery.go | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/pkg/network/discovery.go b/pkg/network/discovery.go index 7b9f4d20d..cffcf8850 100644 --- a/pkg/network/discovery.go +++ b/pkg/network/discovery.go @@ -55,9 +55,6 @@ func NewDefaultDiscovery(dt time.Duration, ts Transporter) *DefaultDiscovery { // BackFill implements the Discoverer interface and will backfill the // the pool with the given addresses. func (d *DefaultDiscovery) BackFill(addrs ...string) { - if len(d.pool) == maxPoolSize { - return - } for _, addr := range addrs { d.backFill <- addr } @@ -68,6 +65,17 @@ func (d *DefaultDiscovery) PoolCount() int { return len(d.pool) } +// pushToPoolOrDrop tries to push address given into the pool, but if the pool +// is already full, it just drops it +func (d *DefaultDiscovery) pushToPoolOrDrop(addr string) { + select { + case d.pool <- addr: + // ok, queued + default: + // whatever + } +} + // RequestRemote will try to establish a connection with n nodes. func (d *DefaultDiscovery) RequestRemote(n int) { d.requestCh <- n @@ -145,12 +153,12 @@ func (d *DefaultDiscovery) run() { if _, ok := d.addrs[addr]; !ok { d.addrs[addr] = true d.unconnectedAddrs[addr] = connRetries - d.pool <- addr + d.pushToPoolOrDrop(addr) } case addr := <-d.badAddrCh: d.unconnectedAddrs[addr]-- if d.unconnectedAddrs[addr] > 0 { - d.pool <- addr + d.pushToPoolOrDrop(addr) } else { d.badAddrs[addr] = true delete(d.unconnectedAddrs, addr)