diff options
author | Sage Weil <sage@inktank.com> | 2013-07-28 08:59:21 -0700 |
---|---|---|
committer | Sage Weil <sage@inktank.com> | 2013-07-29 12:12:14 -0700 |
commit | a6cd9fea50a4bd7048a222617a2bfe0680f7a969 (patch) | |
tree | f6c21ee4ac95d73e7cc80602056422f7bdd2dbfa | |
parent | e24b50225c841a650d9303041bbe811e04bdd668 (diff) | |
download | ceph-a6cd9fea50a4bd7048a222617a2bfe0680f7a969.tar.gz |
osd: get initial full map after a map gap
If there is a gap in our map history, get the full range of maps that
the mon has. Make sure the first one is a full map.
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
-rw-r--r-- | src/osd/OSD.cc | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/src/osd/OSD.cc b/src/osd/OSD.cc index 3fd818e04e3..a71c1e9af21 100644 --- a/src/osd/OSD.cc +++ b/src/osd/OSD.cc @@ -4957,13 +4957,22 @@ void OSD::handle_osd_map(MOSDMap *m) if (first > osdmap->get_epoch() + 1) { dout(10) << "handle_osd_map message skips epochs " << osdmap->get_epoch() + 1 << ".." << (first-1) << dendl; - if ((m->oldest_map < first && osdmap->get_epoch() == 0) || - m->oldest_map <= osdmap->get_epoch() + 1) { + if (m->oldest_map <= osdmap->get_epoch() + 1) { monc->sub_want("osdmap", osdmap->get_epoch()+1, CEPH_SUBSCRIBE_ONETIME); monc->renew_subs(); m->put(); return; } + // always try to get the full range of maps--as many as we can. this + // 1- is good to have + // 2- is at present the only way to ensure that we get a *full* map as + // the first map! + if (m->oldest_map < first) { + monc->sub_want("osdmap", m->oldest_map - 1, CEPH_SUBSCRIBE_ONETIME); + monc->renew_subs(); + m->put(); + return; + } skip_maps = true; } |