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>
(cherry picked from commit
6b858be0676f937a99dbd51321497f30c3a0097f)
(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()