From d0acbe1b4df256a0bc48466281a8f94b3bf4b3e3 Mon Sep 17 00:00:00 2001 From: Bugen Zhao Date: Thu, 28 Nov 2024 15:05:37 +0800 Subject: [PATCH] fix(meta): do not release connection to in-memory SQLite for meta store --- src/meta/src/controller/mod.rs | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/src/meta/src/controller/mod.rs b/src/meta/src/controller/mod.rs index 3663fcb747e6b..8ebede9a65c5a 100644 --- a/src/meta/src/controller/mod.rs +++ b/src/meta/src/controller/mod.rs @@ -64,14 +64,26 @@ pub struct SqlMetaStore { pub endpoint: String, } -pub const IN_MEMORY_STORE: &str = "sqlite::memory:"; - impl SqlMetaStore { /// Connect to the SQL meta store based on the given configuration. pub async fn connect(backend: MetaStoreBackend) -> Result { Ok(match backend { MetaStoreBackend::Mem => { - let conn = sea_orm::Database::connect(IN_MEMORY_STORE).await?; + const IN_MEMORY_STORE: &str = "sqlite::memory:"; + + let mut options = sea_orm::ConnectOptions::new(IN_MEMORY_STORE); + + options + .max_connections(1) + .min_connections(1) + // Releasing the connection to in-memory SQLite database is unacceptable + // because it will clear the database. Set a large enough timeout to prevent it. + // `sqlx` actually supports disabling these timeouts by passing a `None`, but + // `sea-orm` does not expose this option. + .idle_timeout(Duration::MAX / 4) + .max_lifetime(Duration::MAX / 4); + + let conn = sea_orm::Database::connect(options).await?; Self { conn, endpoint: IN_MEMORY_STORE.to_owned(),