]> git.apps.os.sepia.ceph.com Git - ceph.git/commitdiff
osd: handle race between osdmap and prepare_to_stop 1798/head
authorSage Weil <sage@inktank.com>
Fri, 9 May 2014 16:20:34 +0000 (09:20 -0700)
committerSage Weil <sage@inktank.com>
Fri, 9 May 2014 16:20:34 +0000 (09:20 -0700)
If we get a MOSDMarkMeDown message and set service.state == STOPPING, we
kick the prepare_to_stop() thread.  Normally, it will wake up and then
set osd.state == STOPPING, and when we process the map message next we
will not warn.  However, if dispatch() takes the lock instead and processes
the map, it will fail the preparing_to_stop check and issue a spurious
warning.

Fix by checking for either preparing_to_stop or stopping.

Fixes: #8319
Backport: firefly, emperor, dumpling
Signed-off-by: Sage Weil <sage@inktank.com>
src/osd/OSD.cc

index 220eac652723e8ee5e3968b27b6cfe41257afa59..576022937a1fe1b7ada93a6cefb32d6fb3b91470 100644 (file)
@@ -5851,7 +5851,7 @@ void OSD::handle_osd_map(MOSDMap *m)
               (osdmap->get_hb_front_addr(whoami) != entity_addr_t() &&
                 !osdmap->get_hb_front_addr(whoami).probably_equals(hb_front_server_messenger->get_myaddr()))) {
       if (!osdmap->is_up(whoami)) {
-       if (service.is_preparing_to_stop()) {
+       if (service.is_preparing_to_stop() || service.is_stopping()) {
          service.got_stop_ack();
        } else {
          clog.warn() << "map e" << osdmap->get_epoch()