From: Sage Weil Date: Tue, 11 Sep 2018 16:12:22 +0000 (-0500) Subject: osd/PG: avoid choose_acting picking want with > pool size items X-Git-Tag: v13.2.3~153^2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=a0d49cf83ae3b845f2724aec28234d8796c66747;p=ceph.git osd/PG: avoid choose_acting picking want with > pool size items If the pool size recently changed, we might see an up that is larger than the pool size. Or, we might already have selected a primary that is not part of up, and then add all up osds and end up with a want that is too big. Fixes: http://tracker.ceph.com/issues/35924 Signed-off-by: Sage Weil (cherry picked from commit c3e2990c39952a1fc4593076c5b2f0dea6cdcdd3) --- diff --git a/src/osd/PG.cc b/src/osd/PG.cc index 25034c7e2b4..80b2e038aa6 100644 --- a/src/osd/PG.cc +++ b/src/osd/PG.cc @@ -1359,6 +1359,9 @@ void PG::calc_replicated_acting( usable++; ss << " osd." << *i << " (up) accepted " << cur_info << std::endl; } + if (want->size() >= size) { + break; + } } if (usable >= size) {