From: Kefu Chai Date: Thu, 28 Jan 2016 10:09:53 +0000 (-0800) Subject: mon: compact full epochs also X-Git-Tag: v10.0.4~106^2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=refs%2Fpull%2F7396%2Fhead;p=ceph.git mon: compact full epochs also by compacting the ${prefix}.${start}..${prefix}..${end} does not necessary compact the range of ${prefix}."full_"${start}.. ${prefix}."full_"${end}. so when more and more epochs get trimmed with out a full range compaction, the size of monitor store could be very large. Fixes: #14537 Signed-off-by: Kefu Chai --- diff --git a/src/mon/PaxosService.cc b/src/mon/PaxosService.cc index 141a28be9e3..ab169b8b9c3 100644 --- a/src/mon/PaxosService.cc +++ b/src/mon/PaxosService.cc @@ -388,6 +388,9 @@ void PaxosService::trim(MonitorDBStore::TransactionRef t, if (g_conf->mon_compact_on_trim) { dout(20) << " compacting prefix " << get_service_name() << dendl; t->compact_range(get_service_name(), stringify(from - 1), stringify(to)); + t->compact_range(get_service_name(), + mon->store->combine_strings(full_prefix_name, from - 1), + mon->store->combine_strings(full_prefix_name, to)); } }