mirror of https://github.com/laurent22/joplin.git
Doc: Added more info about sync lock refresh mechanism
parent
5f410e80e6
commit
cf78204c85
|
@ -292,6 +292,12 @@ export default class LockHandler {
|
||||||
if (!this.refreshTimers_[handle]) return defer(); // Timeout has been cleared
|
if (!this.refreshTimers_[handle]) return defer(); // Timeout has been cleared
|
||||||
|
|
||||||
if (!hasActiveLock) {
|
if (!hasActiveLock) {
|
||||||
|
// If the previous lock has expired, we shouldn't try to acquire a new one. This is because other clients might have performed
|
||||||
|
// in the meantime operations that invalidates the current operation. For example, another client might have upgraded the
|
||||||
|
// sync target in the meantime, so any active operation should be cancelled here. Or if the current client was upgraded
|
||||||
|
// the sync target, another client might have synced since then, making any cached data invalid.
|
||||||
|
// In some cases it should be safe to re-acquire a lock but adding support for this would make the algorithm more complex
|
||||||
|
// without much benefits.
|
||||||
error = new JoplinError('Lock has expired', 'lockExpired');
|
error = new JoplinError('Lock has expired', 'lockExpired');
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -13,6 +13,10 @@ For example, if a client is currently syncing, it must stop doing so if it could
|
||||||
|
|
||||||
For example, if a client is upgrading a target, it must stop doing so if it couldn't refresh the lock within Y seconds.
|
For example, if a client is upgrading a target, it must stop doing so if it couldn't refresh the lock within Y seconds.
|
||||||
|
|
||||||
|
If the previous lock has expired, we shouldn't try to acquire a new one. This is because other clients, seeing no active lock, might have performed in the meantime operations that invalidates the current operation. For example, another client might have upgraded the sync target, so any active sync with an expired lock should be cancelled. Or if the current client was upgrading the sync target, another client might have synced since then, making any cached data invalid.
|
||||||
|
|
||||||
|
In some cases it should be safe to re-acquire a lock but adding support for this would make the algorithm more complex without much benefits.
|
||||||
|
|
||||||
# Acquiring a SYNC lock
|
# Acquiring a SYNC lock
|
||||||
|
|
||||||
- The client check if there is a valid EXCLUSIVE lock on the target
|
- The client check if there is a valid EXCLUSIVE lock on the target
|
||||||
|
|
Loading…
Reference in New Issue