summaryrefslogtreecommitdiffstats
path: root/src/osd/OSD.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/osd/OSD.cc')
-rw-r--r--src/osd/OSD.cc42
1 files changed, 26 insertions, 16 deletions
diff --git a/src/osd/OSD.cc b/src/osd/OSD.cc
index 8799b7933a3..1368c9d654e 100644
--- a/src/osd/OSD.cc
+++ b/src/osd/OSD.cc
@@ -736,20 +736,24 @@ void OSDService::check_full_status(const osd_stat_t &osd_stat)
return;
}
float nearfull_ratio = osdmap->get_nearfull_ratio();
- float full_ratio = std::max(osdmap->get_full_ratio(), nearfull_ratio);
+ float backfillfull_ratio = std::max(osdmap->get_backfillfull_ratio(), nearfull_ratio);
+ float full_ratio = std::max(osdmap->get_full_ratio(), backfillfull_ratio);
float failsafe_ratio = std::max(get_failsafe_full_ratio(), full_ratio);
if (!osdmap->test_flag(CEPH_OSDMAP_REQUIRE_LUMINOUS)) {
// use the failsafe for nearfull and full; the mon isn't using the
// flags anyway because we're mid-upgrade.
full_ratio = failsafe_ratio;
+ backfillfull_ratio = failsafe_ratio;
nearfull_ratio = failsafe_ratio;
} else if (full_ratio <= 0 ||
+ backfillfull_ratio <= 0 ||
nearfull_ratio <= 0) {
- derr << __func__ << " full_ratio or nearfull_ratio is <= 0" << dendl;
+ derr << __func__ << " full_ratio, backfillfull_ratio or nearfull_ratio is <= 0" << dendl;
// use failsafe flag. ick. the monitor did something wrong or the user
// did something stupid.
full_ratio = failsafe_ratio;
+ backfillfull_ratio = failsafe_ratio;
nearfull_ratio = failsafe_ratio;
}
@@ -759,6 +763,8 @@ void OSDService::check_full_status(const osd_stat_t &osd_stat)
new_state = FAILSAFE;
} else if (ratio > full_ratio || injectfull) {
new_state = FULL;
+ } else if (ratio > backfillfull_ratio) {
+ new_state = BACKFILLFULL;
} else if (ratio > nearfull_ratio) {
new_state = NEARFULL;
} else {
@@ -766,6 +772,7 @@ void OSDService::check_full_status(const osd_stat_t &osd_stat)
}
dout(20) << __func__ << " cur ratio " << ratio
<< ". nearfull_ratio " << nearfull_ratio
+ << ". backfillfull_ratio " << backfillfull_ratio
<< ", full_ratio " << full_ratio
<< ", failsafe_ratio " << failsafe_ratio
<< ", new state " << get_full_state_name(new_state)
@@ -793,6 +800,8 @@ bool OSDService::need_fullness_update()
if (osdmap->exists(whoami)) {
if (osdmap->get_state(whoami) & CEPH_OSD_FULL) {
cur = FULL;
+ } else if (osdmap->get_state(whoami) & CEPH_OSD_BACKFILLFULL) {
+ cur = BACKFILLFULL;
} else if (osdmap->get_state(whoami) & CEPH_OSD_NEARFULL) {
cur = NEARFULL;
}
@@ -800,6 +809,8 @@ bool OSDService::need_fullness_update()
s_names want = NONE;
if (is_full())
want = FULL;
+ else if (is_backfillfull())
+ want = BACKFILLFULL;
else if (is_nearfull())
want = NEARFULL;
return want != cur;
@@ -818,15 +829,19 @@ bool OSDService::check_failsafe_full()
return true;
}
- if (cur_state == FAILSAFE)
- return true;
- return false;
+ return cur_state == FAILSAFE;
}
bool OSDService::is_nearfull()
{
Mutex::Locker l(full_status_lock);
- return cur_state == NEARFULL;
+ return cur_state >= NEARFULL;
+}
+
+bool OSDService::is_backfillfull()
+{
+ Mutex::Locker l(full_status_lock);
+ return cur_state >= BACKFILLFULL;
}
bool OSDService::is_full()
@@ -838,18 +853,11 @@ bool OSDService::is_full()
bool OSDService::too_full_for_backfill(ostream &ss)
{
Mutex::Locker l(full_status_lock);
- if (injectfull) {
- // injectfull is either a count of the number of times to return full
- // or if -1 then always return full
- if (injectfull > 0)
- --injectfull;
- ss << "Injected full OSD (" << (injectfull < 0 ? string("set") : std::to_string(injectfull)) << ")";
+ if (cur_state >= BACKFILLFULL) {
+ ss << "current usage is " << cur_ratio << ", which is greater than max allowed ratio";
return true;
}
- double max_ratio;
- max_ratio = cct->_conf->osd_backfill_full_ratio;
- ss << "current usage is " << cur_ratio << ", which is greater than max allowed ratio " << max_ratio;
- return cur_ratio >= max_ratio;
+ return false;
}
void OSDService::update_osd_stat(vector<int>& hb_peers)
@@ -5213,6 +5221,8 @@ void OSD::send_full_update()
unsigned state = 0;
if (service.is_full()) {
state = CEPH_OSD_FULL;
+ } else if (service.is_backfillfull()) {
+ state = CEPH_OSD_BACKFILLFULL;
} else if (service.is_nearfull()) {
state = CEPH_OSD_NEARFULL;
}