From: Sage Weil Date: Thu, 21 Mar 2019 16:58:29 +0000 (-0500) Subject: mon/MgrStatMonitor: ensure only one copy of initial service map X-Git-Tag: v13.2.7~149^2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=3dc3c1d65854b5f1edf72104b2b0bd9bacc8019b;p=ceph.git mon/MgrStatMonitor: ensure only one copy of initial service map It's possible for create_pending to be called multiple times. Fixes: http://tracker.ceph.com/issues/38839 Signed-off-by: Sage Weil (cherry picked from commit 204a8deacd2068989bd52eb130f4aac434b45f35) --- diff --git a/src/mon/MgrStatMonitor.cc b/src/mon/MgrStatMonitor.cc index 9db8ac4e8699..6ec5c436280e 100644 --- a/src/mon/MgrStatMonitor.cc +++ b/src/mon/MgrStatMonitor.cc @@ -34,6 +34,7 @@ void MgrStatMonitor::create_initial() dout(10) << __func__ << dendl; version = 0; service_map.epoch = 1; + pending_service_map_bl.clear(); encode(service_map, pending_service_map_bl, CEPH_FEATURES_ALL); } @@ -54,7 +55,8 @@ void MgrStatMonitor::update_from_paxos(bool *need_bootstrap) << " service_map e" << service_map.epoch << dendl; } catch (buffer::error& e) { - derr << "failed to decode mgrstat state; luminous dev version?" << dendl; + derr << "failed to decode mgrstat state; luminous dev version? " + << e.what() << dendl; } } check_subs();