mirror of
https://github.com/ceph/ceph
synced 2025-01-04 02:02:36 +00:00
mds: adjust subtree popularity after rename
Signed-off-by: "Yan, Zheng" <zyan@redhat.com>
This commit is contained in:
parent
e9689c1ff7
commit
bedd98f878
@ -1271,6 +1271,36 @@ void MDBalancer::add_import(CDir *dir, utime_t now)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MDBalancer::adjust_pop_for_rename(CDir *pdir, CDir *dir, utime_t now, bool inc)
|
||||||
|
{
|
||||||
|
DecayRate& rate = mds->mdcache->decayrate;
|
||||||
|
|
||||||
|
bool adjust_subtree_nest = dir->is_auth();
|
||||||
|
bool adjust_subtree = adjust_subtree_nest && !dir->is_subtree_root();
|
||||||
|
while (true) {
|
||||||
|
if (inc) {
|
||||||
|
pdir->pop_nested.add(now, rate, dir->pop_nested);
|
||||||
|
if (adjust_subtree)
|
||||||
|
pdir->pop_auth_subtree.add(now, rate, dir->pop_auth_subtree);
|
||||||
|
|
||||||
|
if (adjust_subtree_nest)
|
||||||
|
pdir->pop_auth_subtree_nested.add(now, rate, dir->pop_auth_subtree_nested);
|
||||||
|
} else {
|
||||||
|
pdir->pop_nested.sub(now, rate, dir->pop_nested);
|
||||||
|
if (adjust_subtree)
|
||||||
|
pdir->pop_auth_subtree.sub(now, rate, dir->pop_auth_subtree);
|
||||||
|
|
||||||
|
if (adjust_subtree_nest)
|
||||||
|
pdir->pop_auth_subtree_nested.sub(now, rate, dir->pop_auth_subtree_nested);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pdir->is_subtree_root())
|
||||||
|
adjust_subtree = false;
|
||||||
|
pdir = pdir->inode->get_parent_dir();
|
||||||
|
if (!pdir) break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MDBalancer::handle_mds_failure(mds_rank_t who)
|
void MDBalancer::handle_mds_failure(mds_rank_t who)
|
||||||
{
|
{
|
||||||
if (0 == who) {
|
if (0 == who) {
|
||||||
|
@ -51,6 +51,7 @@ public:
|
|||||||
|
|
||||||
void subtract_export(CDir *ex, utime_t now);
|
void subtract_export(CDir *ex, utime_t now);
|
||||||
void add_import(CDir *im, utime_t now);
|
void add_import(CDir *im, utime_t now);
|
||||||
|
void adjust_pop_for_rename(CDir *pdir, CDir *dir, utime_t now, bool inc);
|
||||||
|
|
||||||
void hit_inode(utime_t now, CInode *in, int type, int who=-1);
|
void hit_inode(utime_t now, CInode *in, int type, int who=-1);
|
||||||
void hit_dir(utime_t now, CDir *dir, int type, int who=-1, double amount=1.0);
|
void hit_dir(utime_t now, CDir *dir, int type, int who=-1, double amount=1.0);
|
||||||
|
@ -809,7 +809,7 @@ void MDCache::list_subtrees(list<CDir*>& ls)
|
|||||||
* merge with parent and/or child subtrees, if is it appropriate.
|
* merge with parent and/or child subtrees, if is it appropriate.
|
||||||
* merge can ONLY happen if both parent and child have unambiguous auth.
|
* merge can ONLY happen if both parent and child have unambiguous auth.
|
||||||
*/
|
*/
|
||||||
void MDCache::adjust_subtree_auth(CDir *dir, mds_authority_t auth)
|
void MDCache::adjust_subtree_auth(CDir *dir, mds_authority_t auth, bool adjust_pop)
|
||||||
{
|
{
|
||||||
dout(7) << "adjust_subtree_auth " << dir->get_dir_auth() << " -> " << auth
|
dout(7) << "adjust_subtree_auth " << dir->get_dir_auth() << " -> " << auth
|
||||||
<< " on " << *dir << dendl;
|
<< " on " << *dir << dendl;
|
||||||
@ -864,7 +864,7 @@ void MDCache::adjust_subtree_auth(CDir *dir, mds_authority_t auth)
|
|||||||
root = dir;
|
root = dir;
|
||||||
|
|
||||||
// adjust recursive pop counters
|
// adjust recursive pop counters
|
||||||
if (dir->is_auth()) {
|
if (adjust_pop && dir->is_auth()) {
|
||||||
utime_t now = ceph_clock_now();
|
utime_t now = ceph_clock_now();
|
||||||
CDir *p = dir->get_parent_dir();
|
CDir *p = dir->get_parent_dir();
|
||||||
while (p) {
|
while (p) {
|
||||||
@ -909,7 +909,7 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void MDCache::try_subtree_merge_at(CDir *dir, set<CInode*> *to_eval)
|
void MDCache::try_subtree_merge_at(CDir *dir, set<CInode*> *to_eval, bool adjust_pop)
|
||||||
{
|
{
|
||||||
dout(10) << "try_subtree_merge_at " << *dir << dendl;
|
dout(10) << "try_subtree_merge_at " << *dir << dendl;
|
||||||
|
|
||||||
@ -941,7 +941,7 @@ void MDCache::try_subtree_merge_at(CDir *dir, set<CInode*> *to_eval)
|
|||||||
subtrees[parent].erase(dir);
|
subtrees[parent].erase(dir);
|
||||||
|
|
||||||
// adjust popularity?
|
// adjust popularity?
|
||||||
if (dir->is_auth()) {
|
if (adjust_pop && dir->is_auth()) {
|
||||||
utime_t now = ceph_clock_now();
|
utime_t now = ceph_clock_now();
|
||||||
CDir *p = dir->get_parent_dir();
|
CDir *p = dir->get_parent_dir();
|
||||||
while (p) {
|
while (p) {
|
||||||
@ -1325,6 +1325,7 @@ void MDCache::adjust_subtree_after_rename(CInode *diri, CDir *olddir, bool pop)
|
|||||||
dout(10) << "adjust_subtree_after_rename " << *diri << " from " << *olddir << dendl;
|
dout(10) << "adjust_subtree_after_rename " << *diri << " from " << *olddir << dendl;
|
||||||
|
|
||||||
//show_subtrees();
|
//show_subtrees();
|
||||||
|
utime_t now = ceph_clock_now();
|
||||||
|
|
||||||
CDir *newdir = diri->get_parent_dir();
|
CDir *newdir = diri->get_parent_dir();
|
||||||
|
|
||||||
@ -1353,12 +1354,12 @@ void MDCache::adjust_subtree_after_rename(CInode *diri, CDir *olddir, bool pop)
|
|||||||
CDir *newparent = get_subtree_root(newdir);
|
CDir *newparent = get_subtree_root(newdir);
|
||||||
dout(10) << " new parent " << *newparent << dendl;
|
dout(10) << " new parent " << *newparent << dendl;
|
||||||
|
|
||||||
|
if (olddir != newdir)
|
||||||
|
mds->balancer->adjust_pop_for_rename(olddir, dir, now, false);
|
||||||
|
|
||||||
if (oldparent == newparent) {
|
if (oldparent == newparent) {
|
||||||
dout(10) << "parent unchanged for " << *dir << " at " << *oldparent << dendl;
|
dout(10) << "parent unchanged for " << *dir << " at " << *oldparent << dendl;
|
||||||
continue;
|
} else if (dir->is_subtree_root()) {
|
||||||
}
|
|
||||||
|
|
||||||
if (dir->is_subtree_root()) {
|
|
||||||
// children are fine. change parent.
|
// children are fine. change parent.
|
||||||
dout(10) << "moving " << *dir << " from " << *oldparent << " to " << *newparent << dendl;
|
dout(10) << "moving " << *dir << " from " << *oldparent << " to " << *newparent << dendl;
|
||||||
assert(subtrees[oldparent].count(dir));
|
assert(subtrees[oldparent].count(dir));
|
||||||
@ -1366,7 +1367,7 @@ void MDCache::adjust_subtree_after_rename(CInode *diri, CDir *olddir, bool pop)
|
|||||||
assert(subtrees.count(newparent));
|
assert(subtrees.count(newparent));
|
||||||
subtrees[newparent].insert(dir);
|
subtrees[newparent].insert(dir);
|
||||||
// caller is responsible for 'eval diri'
|
// caller is responsible for 'eval diri'
|
||||||
try_subtree_merge_at(dir, NULL);
|
try_subtree_merge_at(dir, NULL, false);
|
||||||
} else {
|
} else {
|
||||||
// mid-subtree.
|
// mid-subtree.
|
||||||
|
|
||||||
@ -1391,11 +1392,14 @@ void MDCache::adjust_subtree_after_rename(CInode *diri, CDir *olddir, bool pop)
|
|||||||
|
|
||||||
// did auth change?
|
// did auth change?
|
||||||
if (oldparent->authority() != newparent->authority()) {
|
if (oldparent->authority() != newparent->authority()) {
|
||||||
adjust_subtree_auth(dir, oldparent->authority());
|
adjust_subtree_auth(dir, oldparent->authority(), false);
|
||||||
// caller is responsible for 'eval diri'
|
// caller is responsible for 'eval diri'
|
||||||
try_subtree_merge_at(dir, NULL);
|
try_subtree_merge_at(dir, NULL, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (olddir != newdir)
|
||||||
|
mds->balancer->adjust_pop_for_rename(newdir, dir, now, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
show_subtrees();
|
show_subtrees();
|
||||||
|
@ -315,7 +315,7 @@ protected:
|
|||||||
public:
|
public:
|
||||||
bool is_subtrees() { return !subtrees.empty(); }
|
bool is_subtrees() { return !subtrees.empty(); }
|
||||||
void list_subtrees(list<CDir*>& ls);
|
void list_subtrees(list<CDir*>& ls);
|
||||||
void adjust_subtree_auth(CDir *root, mds_authority_t auth);
|
void adjust_subtree_auth(CDir *root, mds_authority_t auth, bool adjust_pop=true);
|
||||||
void adjust_subtree_auth(CDir *root, mds_rank_t a, mds_rank_t b=CDIR_AUTH_UNKNOWN) {
|
void adjust_subtree_auth(CDir *root, mds_rank_t a, mds_rank_t b=CDIR_AUTH_UNKNOWN) {
|
||||||
adjust_subtree_auth(root, mds_authority_t(a,b));
|
adjust_subtree_auth(root, mds_authority_t(a,b));
|
||||||
}
|
}
|
||||||
@ -329,7 +329,7 @@ public:
|
|||||||
}
|
}
|
||||||
void map_dirfrag_set(list<dirfrag_t>& dfs, set<CDir*>& result);
|
void map_dirfrag_set(list<dirfrag_t>& dfs, set<CDir*>& result);
|
||||||
void try_subtree_merge(CDir *root);
|
void try_subtree_merge(CDir *root);
|
||||||
void try_subtree_merge_at(CDir *root, set<CInode*> *to_eval);
|
void try_subtree_merge_at(CDir *root, set<CInode*> *to_eval, bool adjust_pop=true);
|
||||||
void subtree_merge_writebehind_finish(CInode *in, MutationRef& mut);
|
void subtree_merge_writebehind_finish(CInode *in, MutationRef& mut);
|
||||||
void eval_subtree_root(CInode *diri);
|
void eval_subtree_root(CInode *diri);
|
||||||
CDir *get_subtree_root(CDir *dir);
|
CDir *get_subtree_root(CDir *dir);
|
||||||
|
Loading…
Reference in New Issue
Block a user