[skip ci] sync stuck watch dog

This commit is contained in:
Matthew Fosse 2024-12-18 17:00:23 -05:00
parent ac847d8b93
commit c2e764f77b

View file

@ -253,7 +253,7 @@ Future<void> onStart(ServiceInstance service) async {
if (progress > 0.999 && shouldSync) { if (progress > 0.999 && shouldSync) {
syncedTicks++; syncedTicks++;
if (syncedTicks > 10) { if (syncedTicks > 5) {
syncedTicks = 0; syncedTicks = 0;
printV("WALLET $i SYNCED"); printV("WALLET $i SYNCED");
wallet.stopSync(); wallet.stopSync();
@ -374,25 +374,27 @@ Future<void> onStart(ServiceInstance service) async {
} }
}); });
// setup a watch dog to restart the sync process if it gets stuck: // setup a watch dog to restart the wallet sync process if it appears to get stuck:
List<double> lastFewProgresses = []; List<double> lastFewProgresses = [];
_stuckSyncTimer?.cancel(); _stuckSyncTimer?.cancel();
_stuckSyncTimer = Timer.periodic(const Duration(seconds: 10), (timer) async { _stuckSyncTimer = Timer.periodic(const Duration(seconds: 10), (timer) async {
// TODO: finish this if (syncingWallets.isEmpty) return;
// if (syncStatus is! SyncingSyncStatus) return; final wallet = syncingWallets.first;
// if (syncStatus.progress() > 0.98) return; // don't check if we're close to synced final syncStatus = wallet.syncStatus;
// lastFewProgresses.add(syncStatus.progress()); if (syncStatus is! SyncingSyncStatus) return;
// if (lastFewProgresses.length < 10) return; if (syncStatus.progress() > SYNC_THRESHOLD) return; // don't bother checking if we're close to synced
// // limit list size to 10: lastFewProgresses.add(syncStatus.progress());
// while (lastFewProgresses.length > 10) { if (lastFewProgresses.length < 10) return;
// lastFewProgresses.removeAt(0); // limit list size to 10:
// } while (lastFewProgresses.length > 10) {
// // if the progress is the same over the last 100 seconds, restart the sync: lastFewProgresses.removeAt(0);
// if (lastFewProgresses.every((p) => p == lastFewProgresses.first)) { }
// printV("mweb syncing is stuck, restarting..."); // if the progress is the same over the last 100 seconds, restart the sync:
// syncStatus = LostConnectionSyncStatus(); if (lastFewProgresses.every((p) => p == lastFewProgresses.first)) {
// await stopSync(); printV("syncing appears to be stuck, restarting...");
// } await wallet.stopSync();
await wallet.startSync();
}
}); });
}); });
} }