diff --git a/pkg/kv/kvserver/replica_proposal.go b/pkg/kv/kvserver/replica_proposal.go index 5f8548109c45..162d76b7ae32 100644 --- a/pkg/kv/kvserver/replica_proposal.go +++ b/pkg/kv/kvserver/replica_proposal.go @@ -418,13 +418,14 @@ func (r *Replica) leasePostApplyLocked( } } - // Potentially re-gossip if the range contains node liveness data. We need to - // perform this gossip at startup as soon as possible. We also need to perform - // this gossip if we're taking over after a leaseholder failure. In both cases, - // incremental liveness updates may have been lost, so we want to make sure that - // the latest view of node liveness ends up in gossip. - nls := keys.NodeLivenessSpan - if leaseChangingHands && iAmTheLeaseHolder && kvserverbase.ContainsKeyRange(r.descRLocked(), nls.Key, nls.EndKey) { + // Potentially re-gossip if the range contains system data (e.g. system + // config or node liveness). We need to perform this gossip at startup as + // soon as possible. Trying to minimize how often we gossip is a fool's + // errand. The node liveness info will be gossiped frequently (every few + // seconds) in any case due to the liveness heartbeats. And the system config + // will be gossiped rarely because it falls on a range with an epoch-based + // range lease that is only reacquired extremely infrequently. + if iAmTheLeaseHolder { // NB: run these in an async task to keep them out of the critical section // (r.mu is held here). _ = r.store.stopper.RunAsyncTask(r.AnnotateCtx(context.Background()), "lease-triggers", func(ctx context.Context) {