Skip to content

Commit

Permalink
update the entity model to provision crdb+kv
Browse files Browse the repository at this point in the history
  • Loading branch information
abersnaze authored and tcdevoe committed Dec 28, 2023
1 parent e3b17da commit 8d443a5
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 2 deletions.
20 changes: 19 additions & 1 deletion service_capacity_modeling/models/org/netflix/entity.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,23 @@ def extra_model_arguments_schema() -> Dict[str, Any]:
def compose_with(
user_desires: CapacityDesires, extra_model_arguments: Dict[str, Any]
) -> Tuple[Tuple[str, Callable[[CapacityDesires], CapacityDesires]], ...]:
def _modify_crdb_desires(
user_desires: CapacityDesires,
) -> CapacityDesires:
relaxed = user_desires.copy(deep=True)
item_count = relaxed.data_shape.estimated_state_item_count
# based on the nts cluster where the version store is 10x the prime store
if item_count is None:
# assume 10 KB items
item_count = user_desires.data_shape.estimated_state_size_gib.scale(
1024 * 1024 / 10
)
# assume 512 B to track the id/version of each item
relaxed.data_shape.estimated_state_size_gib = item_count.scale(
512 / 1024**3 # bytes per item in GiB
)
return relaxed

def _modify_elasticsearch_desires(
user_desires: CapacityDesires,
) -> CapacityDesires:
Expand All @@ -69,7 +86,8 @@ def _modify_elasticsearch_desires(
return relaxed

return (
("org.netflix.cassandra", lambda x: x),
("org.netflix.cockroachdb", _modify_crdb_desires),
("org.netflix.key-value", lambda x: x),
("org.netflix.elasticsearch", _modify_elasticsearch_desires),
)

Expand Down
17 changes: 16 additions & 1 deletion tests/netflix/test_entity.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ def test_entity_increasing_qps_simple():
),
data_shape=DataShape(
estimated_state_size_gib=Interval(
low=20, mid=200, high=2000, confidence=0.98
low=2, mid=20, high=200, confidence=0.98
),
),
)
Expand All @@ -33,6 +33,21 @@ def test_entity_increasing_qps_simple():
simulations=256,
)

# the set of cluster types the planner chose
types = {
c.cluster_type
for c in list(cap_plan.least_regret[0].candidate_clusters.regional)
+ list(cap_plan.least_regret[0].candidate_clusters.zonal)
}
assert types == {
"dgwentity",
"dgwkv",
"cockroachdb",
"cassandra",
"elasticsearch-data",
"elasticsearch-master",
}

# Check the Java cluster
entity_plan = next(
filter(
Expand Down

0 comments on commit 8d443a5

Please sign in to comment.