mirror of
https://github.com/ceph/ceph
synced 2025-01-01 08:32:24 +00:00
journal: set committing_seq in commit_start
We need to set committing_seq when we first block access to the fs in commit_start(), NOT in commit_started(), as by that time we may have queued all sorts of additional entries for the journal. The committing_seq is all about syncing up with the live fs (via op_apply_start), not what's queued for the journal.
This commit is contained in:
parent
5fa2083f49
commit
d844ddee5d
@ -152,16 +152,16 @@ bool JournalingObjectStore::commit_start()
|
||||
assert(commit_waiters.empty());
|
||||
return false;
|
||||
}
|
||||
dout(10) << "commit_start" << dendl;
|
||||
committing_seq = op_seq;
|
||||
dout(10) << "commit_start committing " << committing_seq << ", blocked" << dendl;
|
||||
return true;
|
||||
}
|
||||
|
||||
void JournalingObjectStore::commit_started()
|
||||
{
|
||||
Mutex::Locker l(lock);
|
||||
dout(10) << "commit_started" << dendl;
|
||||
// allow new ops. (underlying fs should now be committing all prior ops)
|
||||
committing_seq = op_seq;
|
||||
dout(10) << "commit_started committing " << committing_seq << ", unblocking" << dendl;
|
||||
blocked = false;
|
||||
cond.Signal();
|
||||
}
|
||||
@ -169,7 +169,7 @@ void JournalingObjectStore::commit_started()
|
||||
void JournalingObjectStore::commit_finish()
|
||||
{
|
||||
Mutex::Locker l(lock);
|
||||
dout(10) << "commit_finish" << dendl;
|
||||
dout(10) << "commit_finish thru " << committing_seq << dendl;
|
||||
|
||||
if (journal)
|
||||
journal->committed_thru(committing_seq);
|
||||
|
Loading…
Reference in New Issue
Block a user