]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
mon: OSDMonitor: update latest_full while rebuilding full maps
authorJoao Eduardo Luis <joao.luis@inktank.com>
Sun, 15 Sep 2013 20:03:50 +0000 (21:03 +0100)
committerJoao Eduardo Luis <joao.luis@inktank.com>
Sun, 15 Sep 2013 23:33:02 +0000 (00:33 +0100)
Not doing so will make the monitor rebuild the osdmap full versions, even
though they may have been rebuilt before, every time the monitor starts.

This mostly happens when the cluster is left in an unhealthy state for
a long period of time and incremental versions build up.  Even though we
build the full maps on update_from_paxos(), not updating 'full_latest'
leads to the situation initially described.

Fixes: #6322
Signed-off-by: Joao Eduardo Luis <joao.luis@inktank.com>
src/mon/OSDMonitor.cc

index 3f45a18111a20217ce815a5c61bf9147b097d45a..3fa53bf7d578cd902312df043a8ec2fc56d5cf43 100644 (file)
@@ -195,6 +195,7 @@ void OSDMonitor::update_from_paxos(bool *need_bootstrap)
     bufferlist full_bl;
     osdmap.encode(full_bl);
     put_version_full(&t, osdmap.epoch, full_bl);
+    put_version_latest_full(&t, osdmap.epoch);
 
     // share
     dout(1) << osdmap << dendl;