]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
mgr/pg_autoscaler: calculate pool_pg_target using pool size 32592/head
authorDan van der Ster <daniel.vanderster@cern.ch>
Fri, 10 Jan 2020 10:36:20 +0000 (11:36 +0100)
committerDan van der Ster <daniel.vanderster@cern.ch>
Fri, 10 Jan 2020 10:36:20 +0000 (11:36 +0100)
Using raw_used_rate to calculate the pool_pg_target results in too
many PGs for erasure coded pools (e.g. EC 4+2 has raw_used_rate=1.5
but size is 6, so there will be 4x too many PGs). Calculate using
p['size'] instead.

Signed-off-by: Dan van der Ster <daniel.vanderster@cern.ch>
Fixes: https://tracker.ceph.com/issues/43546
src/pybind/mgr/pg_autoscaler/module.py

index e3dc83ff2cd1164d96c3b74dc9bd2cb083025bba..e50860edbe103cc0fbb44b8fdc0043931b3d816a 100644 (file)
@@ -303,7 +303,7 @@ class PgAutoscaler(MgrModule):
             final_ratio = max(capacity_ratio, target_ratio)
 
             # So what proportion of pg allowance should we be using?
-            pool_pg_target = (final_ratio * root_map[root_id].pg_target) / raw_used_rate * bias
+            pool_pg_target = (final_ratio * root_map[root_id].pg_target) / p['size'] * bias
 
             final_pg_target = max(p['options'].get('pg_num_min', PG_NUM_MIN),
                                   nearest_power_of_two(pool_pg_target))