mirror of
https://github.com/status-im/nim-libp2p.git
synced 2025-01-23 03:09:27 +00:00
improve fanout replenish behavior further
This commit is contained in:
parent
509d84f03d
commit
f49e59cb4e
@ -218,6 +218,11 @@ proc heartbeat(g: GossipSub) {.async.} =
|
|||||||
await g.rebalanceMesh(t)
|
await g.rebalanceMesh(t)
|
||||||
|
|
||||||
await g.dropFanoutPeers()
|
await g.dropFanoutPeers()
|
||||||
|
|
||||||
|
# replenish known topics to the fanout
|
||||||
|
for t in toSeq(g.fanout.keys):
|
||||||
|
g.replenishFanout(t)
|
||||||
|
|
||||||
let peers = g.getGossipPeers()
|
let peers = g.getGossipPeers()
|
||||||
var sent: seq[Future[void]]
|
var sent: seq[Future[void]]
|
||||||
for peer in peers.keys:
|
for peer in peers.keys:
|
||||||
@ -470,6 +475,10 @@ method publish*(g: GossipSub,
|
|||||||
if topic in g.topics: # if we're subscribed use the mesh
|
if topic in g.topics: # if we're subscribed use the mesh
|
||||||
peers = g.mesh.getOrDefault(topic)
|
peers = g.mesh.getOrDefault(topic)
|
||||||
else: # not subscribed, send to fanout peers
|
else: # not subscribed, send to fanout peers
|
||||||
|
# try optimistically
|
||||||
|
peers = g.fanout.getOrDefault(topic)
|
||||||
|
if peers.len == 0:
|
||||||
|
# ok we had nothing.. let's try replenish inline
|
||||||
g.replenishFanout(topic)
|
g.replenishFanout(topic)
|
||||||
peers = g.fanout.getOrDefault(topic)
|
peers = g.fanout.getOrDefault(topic)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user