service-capacity-modeling 0.3.101__tar.gz → 0.3.102__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/PKG-INFO +1 -1
  2. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/control.py +1 -28
  3. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/entity.py +0 -29
  4. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling.egg-info/PKG-INFO +1 -1
  5. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/LICENSE +0 -0
  6. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/README.md +0 -0
  7. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/__init__.py +0 -0
  8. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/capacity_planner.py +0 -0
  9. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/enum_utils.py +0 -0
  10. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/__init__.py +0 -0
  11. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/__init__.py +0 -0
  12. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/pricing/aws/3yr-reserved_ec2.json +0 -0
  13. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/pricing/aws/3yr-reserved_rds.json +0 -0
  14. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/pricing/aws/3yr-reserved_zz-overrides.json +0 -0
  15. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/profiles.txt +0 -0
  16. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c5.json +0 -0
  17. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c5a.json +0 -0
  18. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c5d.json +0 -0
  19. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c5n.json +0 -0
  20. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c6a.json +0 -0
  21. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c6i.json +0 -0
  22. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c6id.json +0 -0
  23. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c7a.json +0 -0
  24. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c7i.json +0 -0
  25. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_c8i.json +0 -0
  26. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_db_r6g.json +0 -0
  27. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_db_r6i.json +0 -0
  28. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_db_r7g.json +0 -0
  29. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_db_r7i.json +0 -0
  30. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_i3en.json +0 -0
  31. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_i4i.json +0 -0
  32. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_i7i.json +0 -0
  33. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m4.json +0 -0
  34. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m5.json +0 -0
  35. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m5n.json +0 -0
  36. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m6a.json +0 -0
  37. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m6i.json +0 -0
  38. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m6id.json +0 -0
  39. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m6idn.json +0 -0
  40. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m6in.json +0 -0
  41. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m7a.json +0 -0
  42. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m7i.json +0 -0
  43. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_m8i.json +0 -0
  44. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r4.json +0 -0
  45. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r5.json +0 -0
  46. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r5n.json +0 -0
  47. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r6a.json +0 -0
  48. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r6i.json +0 -0
  49. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r6id.json +0 -0
  50. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r6idn.json +0 -0
  51. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r6in.json +0 -0
  52. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r7a.json +0 -0
  53. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r7i.json +0 -0
  54. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/auto_r8i.json +0 -0
  55. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/manual_drives.json +0 -0
  56. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/manual_instances.json +0 -0
  57. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/hardware/profiles/shapes/aws/manual_services.json +0 -0
  58. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/interface.py +0 -0
  59. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/__init__.py +0 -0
  60. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/common.py +0 -0
  61. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/headroom_strategy.py +0 -0
  62. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/__init__.py +0 -0
  63. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/__init__.py +0 -0
  64. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/aurora.py +0 -0
  65. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/cassandra.py +0 -0
  66. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/counter.py +0 -0
  67. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/crdb.py +0 -0
  68. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/ddb.py +0 -0
  69. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/elasticsearch.py +0 -0
  70. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/evcache.py +0 -0
  71. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/graphkv.py +0 -0
  72. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/iso_date_math.py +0 -0
  73. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/kafka.py +0 -0
  74. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/key_value.py +0 -0
  75. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/postgres.py +0 -0
  76. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/rds.py +0 -0
  77. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/stateless_java.py +0 -0
  78. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/time_series.py +0 -0
  79. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/time_series_config.py +0 -0
  80. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/wal.py +0 -0
  81. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/org/netflix/zookeeper.py +0 -0
  82. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/models/utils.py +0 -0
  83. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/stats.py +0 -0
  84. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/__init__.py +0 -0
  85. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/auto_shape.py +0 -0
  86. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/capture_baseline_costs.py +0 -0
  87. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/data/__init__.py +0 -0
  88. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/fetch_pricing.py +0 -0
  89. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/generate_missing.py +0 -0
  90. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling/tools/instance_families.py +0 -0
  91. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling.egg-info/SOURCES.txt +0 -0
  92. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling.egg-info/dependency_links.txt +0 -0
  93. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling.egg-info/entry_points.txt +0 -0
  94. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling.egg-info/requires.txt +0 -0
  95. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/service_capacity_modeling.egg-info/top_level.txt +0 -0
  96. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/setup.cfg +0 -0
  97. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/setup.py +0 -0
  98. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_arguments.py +0 -0
  99. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_buffers.py +0 -0
  100. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_common.py +0 -0
  101. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_desire_merge.py +0 -0
  102. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_enum_utils.py +0 -0
  103. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_generate_scenarios.py +0 -0
  104. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_hardware.py +0 -0
  105. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_hardware_shapes.py +0 -0
  106. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_headroom_strategy.py +0 -0
  107. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_io2.py +0 -0
  108. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_model_dump.py +0 -0
  109. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_reproducible.py +0 -0
  110. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_simulation.py +0 -0
  111. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_utils.py +0 -0
  112. {service_capacity_modeling-0.3.101 → service_capacity_modeling-0.3.102}/tests/test_working_set.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: service-capacity-modeling
3
- Version: 0.3.101
3
+ Version: 0.3.102
4
4
  Summary: Contains utilities for modeling capacity for pluggable workloads
5
5
  Author: Joseph Lynch
6
6
  Author-email: josephl@netflix.com
@@ -67,30 +67,6 @@ class NflxControlCapacityModel(CapacityModel):
67
67
  def compose_with(
68
68
  user_desires: CapacityDesires, extra_model_arguments: Dict[str, Any]
69
69
  ) -> Tuple[Tuple[str, Callable[[CapacityDesires], CapacityDesires]], ...]:
70
- def _modify_rds_desires(
71
- user_desires: CapacityDesires,
72
- ) -> CapacityDesires:
73
- """RDS proxy for Control service."""
74
- relaxed = user_desires.model_copy(deep=True)
75
-
76
- # RDS doesn't support tier 0
77
- if relaxed.service_tier == 0:
78
- relaxed.service_tier = 1
79
-
80
- # Control caches reads, so proxy only sees writes + minimal reads
81
- relaxed.query_pattern.estimated_read_per_second = certain_int(1)
82
- if relaxed.query_pattern.estimated_write_per_second:
83
- relaxed.query_pattern.estimated_write_per_second = (
84
- relaxed.query_pattern.estimated_write_per_second.scale(0.05)
85
- )
86
-
87
- # Minimal data footprint for connection metadata
88
- relaxed.data_shape.estimated_state_size_gib = (
89
- relaxed.data_shape.estimated_state_size_gib.scale(0.01)
90
- )
91
-
92
- return relaxed
93
-
94
70
  def _modify_postgres_desires(
95
71
  user_desires: CapacityDesires,
96
72
  ) -> CapacityDesires:
@@ -107,10 +83,7 @@ class NflxControlCapacityModel(CapacityModel):
107
83
 
108
84
  return relaxed
109
85
 
110
- return (
111
- ("org.netflix.rds", _modify_rds_desires),
112
- ("org.netflix.postgres", _modify_postgres_desires),
113
- )
86
+ return (("org.netflix.postgres", _modify_postgres_desires),)
114
87
 
115
88
  @staticmethod
116
89
  def default_desires(
@@ -63,34 +63,6 @@ class NflxEntityCapacityModel(CapacityModel):
63
63
  def compose_with(
64
64
  user_desires: CapacityDesires, extra_model_arguments: Dict[str, Any]
65
65
  ) -> Tuple[Tuple[str, Callable[[CapacityDesires], CapacityDesires]], ...]:
66
- def _modify_rds_desires(
67
- user_desires: CapacityDesires,
68
- ) -> CapacityDesires:
69
- """RDS proxy handles connection pooling and auth translation.
70
- Capacity needs are much lower than the backend database."""
71
- relaxed = user_desires.model_copy(deep=True)
72
-
73
- # RDS doesn't support tier 0
74
- if relaxed.service_tier == 0:
75
- relaxed.service_tier = 1
76
-
77
- # Proxy layer sees ~5% of actual load due to connection pooling
78
- if relaxed.query_pattern.estimated_read_per_second:
79
- relaxed.query_pattern.estimated_read_per_second = (
80
- relaxed.query_pattern.estimated_read_per_second.scale(0.05)
81
- )
82
- if relaxed.query_pattern.estimated_write_per_second:
83
- relaxed.query_pattern.estimated_write_per_second = (
84
- relaxed.query_pattern.estimated_write_per_second.scale(0.05)
85
- )
86
-
87
- # Proxy only needs to store connection metadata, not actual data
88
- relaxed.data_shape.estimated_state_size_gib = (
89
- relaxed.data_shape.estimated_state_size_gib.scale(0.01)
90
- )
91
-
92
- return relaxed
93
-
94
66
  def _modify_postgres_desires(
95
67
  user_desires: CapacityDesires,
96
68
  ) -> CapacityDesires:
@@ -128,7 +100,6 @@ class NflxEntityCapacityModel(CapacityModel):
128
100
  return relaxed
129
101
 
130
102
  return (
131
- ("org.netflix.rds", _modify_rds_desires),
132
103
  ("org.netflix.postgres", _modify_postgres_desires),
133
104
  ("org.netflix.key-value", lambda x: x),
134
105
  ("org.netflix.elasticsearch", _modify_elasticsearch_desires),
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: service-capacity-modeling
3
- Version: 0.3.101
3
+ Version: 0.3.102
4
4
  Summary: Contains utilities for modeling capacity for pluggable workloads
5
5
  Author: Joseph Lynch
6
6
  Author-email: josephl@netflix.com