Enable WAL and busy_timeout for each sqlite connection to mitigate db locks,

This commit is contained in:
Shane Handley 2020-06-06 18:26:48 +10:00
parent b380143e4b
commit 24cdea0a4c
2 changed files with 23 additions and 3 deletions

2
.gitignore vendored
View File

@ -36,6 +36,8 @@ todo.txt
# Game data # Game data
*.sqlite *.sqlite
*.sqlite-journal *.sqlite-journal
*.sqlite-wal
*.sqlite-shm
# direnv # direnv
/.envrc /.envrc

View File

@ -6,7 +6,7 @@ mod schema;
extern crate diesel; extern crate diesel;
use diesel::prelude::*; use diesel::{connection::SimpleConnection, prelude::*};
use diesel_migrations::embed_migrations; use diesel_migrations::embed_migrations;
use std::{env, fs, path::PathBuf}; use std::{env, fs, path::PathBuf};
@ -24,8 +24,26 @@ pub fn run_migrations(db_dir: &str) -> Result<(), diesel_migrations::RunMigratio
fn establish_connection(db_dir: &str) -> SqliteConnection { fn establish_connection(db_dir: &str) -> SqliteConnection {
let db_dir = &apply_saves_dir_override(db_dir); let db_dir = &apply_saves_dir_override(db_dir);
let database_url = format!("{}/db.sqlite", db_dir); let database_url = format!("{}/db.sqlite", db_dir);
SqliteConnection::establish(&database_url)
.unwrap_or_else(|_| panic!("Error connecting to {}", database_url)) let connection = SqliteConnection::establish(&database_url)
.unwrap_or_else(|_| panic!("Error connecting to {}", database_url));
// Use Write-Ahead-Logging for improved concurrency: https://sqlite.org/wal.html
// Set a busy timeout (in ms): https://sqlite.org/c3ref/busy_timeout.html
if let Err(error) = connection.batch_execute(
"
PRAGMA journal_mode = WAL;
PRAGMA busy_timeout = 250;
",
) {
log::warn!(
"Failed adding PRAGMA statements while establishing sqlite connection, this will \
result in a higher likelihood of locking errors: {}",
error
);
}
connection
} }
fn apply_saves_dir_override(db_dir: &str) -> String { fn apply_saves_dir_override(db_dir: &str) -> String {