From d439ad95ce7325ffbd3574a2fafce9f51d8080c7 Mon Sep 17 00:00:00 2001 From: Elliott Date: Mon, 11 Mar 2024 01:25:04 -0500 Subject: [PATCH] Set segment count per node to consistent value across defaults and docs (#1477) * Set segment count per node to consistent value across defaults and docs Per https://github.com/thelastpickle/cassandra-reaper/issues/1192 the default should be 64. So, set that everywhere, including docs * Also fix test that assumed 16-segment default * Properly fix computeGlobalSegmentCount256TokenPerNodeTest After reading the actual function, this makes more sense as a fix. * Also fix computeGlobalSegmentCountSingleTokenPerNodeTest --- docs/docs/configuration/reaper_specific/index.html | 2 +- src/docs/content/docs/configuration/reaper_specific.md | 2 +- .../java/io/cassandrareaper/service/RepairRunService.java | 2 +- .../java/io/cassandrareaper/service/RepairRunServiceTest.java | 4 ++-- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/docs/configuration/reaper_specific/index.html b/docs/docs/configuration/reaper_specific/index.html index 7fce058e4..1f7dedd5a 100644 --- a/docs/docs/configuration/reaper_specific/index.html +++ b/docs/docs/configuration/reaper_specific/index.html @@ -523,7 +523,7 @@

scheduleDaysBetween

segmentCountPerNode

Type: Integer

-

Default: 16

+

Default: 64

Defines the default amount of repair segments to create for newly registered Cassandra repair runs, for each node in the cluster. When running a repair run by Reaper, each segment is repaired separately by the Reaper process, until all the segments in a token ring are repaired. The count might be slightly off the defined value, as clusters residing in multiple data centers require additional small token ranges in addition to the expected. This value can be overwritten when executing a repair run via Reaper.

In a 10 nodes cluster, setting a value of 20 segments per node will generate a repair run that splits the work into 200 token subranges. This number can vary due to vnodes (before 1.2.0, Reaper cannot create a segment with multiple token ranges, so the number of segments will be at least the total number of vnodes in the cluster). As Reaper tries to size segments evenly, the presence of very small token ranges can lead to have more segments than expected.

diff --git a/src/docs/content/docs/configuration/reaper_specific.md b/src/docs/content/docs/configuration/reaper_specific.md index e5d3d70dd..5a50893b8 100644 --- a/src/docs/content/docs/configuration/reaper_specific.md +++ b/src/docs/content/docs/configuration/reaper_specific.md @@ -352,7 +352,7 @@ Defines the amount of days to wait between scheduling new repairs. The value con Type: *Integer* -Default: *16* +Default: *64* Defines the default amount of repair segments to create for newly registered Cassandra repair runs, for each node in the cluster. When running a repair run by Reaper, each segment is repaired separately by the Reaper process, until all the segments in a token ring are repaired. The count might be slightly off the defined value, as clusters residing in multiple data centers require additional small token ranges in addition to the expected. This value can be overwritten when executing a repair run via Reaper. diff --git a/src/server/src/main/java/io/cassandrareaper/service/RepairRunService.java b/src/server/src/main/java/io/cassandrareaper/service/RepairRunService.java index 46aebcceb..b0d8a23e1 100644 --- a/src/server/src/main/java/io/cassandrareaper/service/RepairRunService.java +++ b/src/server/src/main/java/io/cassandrareaper/service/RepairRunService.java @@ -62,7 +62,7 @@ public final class RepairRunService { public static final Splitter COMMA_SEPARATED_LIST_SPLITTER = Splitter.on(',').trimResults(CharMatcher.anyOf(" ()[]\"'")).omitEmptyStrings(); - public static final int DEFAULT_SEGMENT_COUNT_PER_NODE = 16; + public static final int DEFAULT_SEGMENT_COUNT_PER_NODE = 64; private static final Logger LOG = LoggerFactory.getLogger(RepairRunService.class); diff --git a/src/server/src/test/java/io/cassandrareaper/service/RepairRunServiceTest.java b/src/server/src/test/java/io/cassandrareaper/service/RepairRunServiceTest.java index 8d7b618f2..20af6113f 100644 --- a/src/server/src/test/java/io/cassandrareaper/service/RepairRunServiceTest.java +++ b/src/server/src/test/java/io/cassandrareaper/service/RepairRunServiceTest.java @@ -189,7 +189,7 @@ public void computeGlobalSegmentCountSingleTokenPerNodeTest() { endpointToRange.put("node2", Lists.newArrayList()); endpointToRange.put("node3", Lists.newArrayList()); - assertEquals(48, RepairRunService.computeGlobalSegmentCount(0, endpointToRange)); + assertEquals(192, RepairRunService.computeGlobalSegmentCount(0, endpointToRange)); } @Test @@ -206,7 +206,7 @@ public void computeGlobalSegmentCount256TokenPerNodeTest() { endpointToRange.put("node2", Lists.newArrayList()); endpointToRange.put("node3", Lists.newArrayList()); - assertEquals(48, RepairRunService.computeGlobalSegmentCount(0, endpointToRange)); + assertEquals(192, RepairRunService.computeGlobalSegmentCount(0, endpointToRange)); } @Test