Page MenuHomePhabricator

Explicitly shuffle nodes before selecting one for cluster sync
ClosedPublic

Authored by epriestley on Oct 5 2018, 9:01 PM.
Tags
None
Referenced Files
F14637452: D19735.diff
Fri, Jan 10, 11:01 PM
Unknown Object (File)
Thu, Dec 12, 10:43 PM
Unknown Object (File)
Thu, Dec 12, 10:43 PM
Unknown Object (File)
Thu, Dec 12, 10:43 PM
Unknown Object (File)
Thu, Dec 12, 10:43 PM
Unknown Object (File)
Thu, Dec 12, 7:56 AM
Unknown Object (File)
Nov 20 2024, 6:44 PM
Unknown Object (File)
Nov 16 2024, 10:17 AM
Subscribers
None

Details

Summary

Depends on D19734. Ref T13202. Ref T13109. Ref T10884. See PHI905. See PHI889. We currently rank cluster nodes in three cases:

  1. when performing a write, we can go to any node (D19734 should make our ranking good);
  2. when performing a read, we can go to any node (currently random, but T10884 discusses ideas to improve our ranking);
  3. when performing an internal synchronization before a read or a write, we must go to an up-to-date node.

Currently, case (3) is not-exactly-deterministic but not random, and we won't spread intracluster traffic acrosss the cluster evenly if, say, half of it is up to date and half of it is still synchronizing. For a given write, I believe all nodes will tend to synchronize from whichever node first received the write today.

Instead, shuffle the list and synchronize from any up-to-date node.

(I think we could improve upon this only by knowing which nodes actually have load and selecting the least-loaded -- doable, but not trivial.)

Test Plan

Poked at it locally, will deploy to secure. This is hard to measure/test terribly convincingly.

Diff Detail

Repository
rP Phabricator
Branch
write2
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 20996
Build 28522: Run Core Tests
Build 28521: arc lint + arc unit