From 4d6aed1b528efc9bdac7cce7922259f5c703ec55 Mon Sep 17 00:00:00 2001 From: Satya Rohith Date: Mon, 10 Oct 2022 13:05:57 +0530 Subject: [PATCH] perf(ext/cache): set journal_mode=wal (#16231) --- ext/cache/sqlite.rs | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/ext/cache/sqlite.rs b/ext/cache/sqlite.rs index 75aa7cc6ee..caf3867774 100644 --- a/ext/cache/sqlite.rs +++ b/ext/cache/sqlite.rs @@ -45,6 +45,16 @@ impl SqliteBackedCache { let connection = rusqlite::Connection::open(&path).unwrap_or_else(|_| { panic!("failed to open cache db at {}", path.display()) }); + // Enable write-ahead-logging mode. + let initial_pragmas = " + -- enable write-ahead-logging mode + PRAGMA journal_mode=WAL; + PRAGMA synchronous=NORMAL; + PRAGMA optimize; + "; + connection + .execute_batch(initial_pragmas) + .expect("failed to execute pragmas"); connection .execute( "CREATE TABLE IF NOT EXISTS cache_storage ( @@ -117,7 +127,7 @@ impl Cache for SqliteBackedCache { tokio::task::spawn_blocking(move || { let db = db.lock(); let cache_exists = db.query_row( - "SELECT count(cache_name) FROM cache_storage WHERE cache_name = ?1", + "SELECT count(id) FROM cache_storage WHERE cache_name = ?1", params![cache_name], |row| { let count: i64 = row.get(0)?;