discovery: add new option to toggle gossip rate limiting

In this commit, we add a new option to toggle gossip rate limiting. This
new option can be useful in contexts that require near instant
propagation of gossip messages like integration tests.
This commit is contained in:
Olaoluwa Osuntokun 2020-11-29 16:13:40 -08:00
parent b1fbbcf562
commit 13a2598ded
No known key found for this signature in database
GPG Key ID: 3BBD59E99B280306
3 changed files with 10 additions and 2 deletions

@ -228,6 +228,11 @@ type Config struct {
// This prevents ranges with old start times from causing us to dump the // This prevents ranges with old start times from causing us to dump the
// graph on connect. // graph on connect.
IgnoreHistoricalFilters bool IgnoreHistoricalFilters bool
// GossipUpdateThrottle if true, then the gossiper will throttle
// gossip updates to once per RebroadcastInterval for any keep-alive
// updates, and once per block for other types of updates.
GossipUpdateThrottle bool
} }
// AuthenticatedGossiper is a subsystem which is responsible for receiving // AuthenticatedGossiper is a subsystem which is responsible for receiving
@ -1965,8 +1970,9 @@ func (d *AuthenticatedGossiper) processNetworkAnnouncement(
// If we have a previous version of the edge being updated, // If we have a previous version of the edge being updated,
// we'll want to rate limit its updates to prevent spam // we'll want to rate limit its updates to prevent spam
// throughout the network. // throughout the network if we're currently throttling such
if nMsg.isRemote && edgeToUpdate != nil { // updates.
if d.cfg.GossipUpdateThrottle && nMsg.isRemote && edgeToUpdate != nil {
// If it's a keep-alive update, we'll only propagate one // If it's a keep-alive update, we'll only propagate one
// if it's been a day since the previous. This follows // if it's been a day since the previous. This follows
// our own heuristic of sending keep-alive updates after // our own heuristic of sending keep-alive updates after

@ -3957,6 +3957,7 @@ func TestRateLimitChannelUpdates(t *testing.T) {
} }
defer cleanup() defer cleanup()
ctx.gossiper.cfg.RebroadcastInterval = time.Hour ctx.gossiper.cfg.RebroadcastInterval = time.Hour
ctx.gossiper.cfg.GossipUpdateThrottle = true
// The graph should start empty. // The graph should start empty.
require.Empty(t, ctx.router.infos) require.Empty(t, ctx.router.infos)

@ -804,6 +804,7 @@ func newServer(cfg *Config, listenAddrs []net.Addr,
MinimumBatchSize: 10, MinimumBatchSize: 10,
SubBatchDelay: time.Second * 5, SubBatchDelay: time.Second * 5,
IgnoreHistoricalFilters: cfg.IgnoreHistoricalGossipFilters, IgnoreHistoricalFilters: cfg.IgnoreHistoricalGossipFilters,
GossipUpdateThrottle: !cfg.ProtocolOptions.NoGossipThrottle(),
}, },
s.identityECDH.PubKey(), s.identityECDH.PubKey(),
) )