From 9825b04c2ad7ffd3dab09135d29e309d853c1314 Mon Sep 17 00:00:00 2001 From: hvlad Date: Sat, 16 Sep 2017 11:18:34 +0300 Subject: [PATCH] Improvement CORE-5614 : Physical backup merge stage could run too long, especially with huge page cache --- src/jrd/nbak.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/jrd/nbak.cpp b/src/jrd/nbak.cpp index 9e36e04a9a..5f489fb449 100644 --- a/src/jrd/nbak.cpp +++ b/src/jrd/nbak.cpp @@ -567,6 +567,7 @@ void BackupManager::endBackup(thread_db* tdbb, bool recover) if (all.getFirst()) { + int n = 0; do { if (--tdbb->tdbb_quantum < 0) JRD_reschedule(tdbb, QUANTUM, true); @@ -577,11 +578,17 @@ void BackupManager::endBackup(thread_db* tdbb, bool recover) NBAK_TRACE(("Merge: page %d is fetched", all.current().db_page)); if (page->pag_scn != current_scn) { - CCH_MARK(tdbb, &window2); + CCH_MARK_SYSTEM(tdbb, &window2); NBAK_TRACE(("Merge: page %d is marked", all.current().db_page)); } CCH_RELEASE(tdbb, &window2); NBAK_TRACE(("Merge: page %d is released", all.current().db_page)); + + if (++n == 512) + { + CCH_flush(tdbb, FLUSH_SYSTEM, 0); + n = 0; + } } while (all.getNext()); }