From 214b78c581319ee012383134107fa5c371febe09 Mon Sep 17 00:00:00 2001 From: metamuffin Date: Thu, 11 Dec 2025 03:25:56 +0100 Subject: rocksdb cache backend --- cache/src/backends/mod.rs | 15 ++++++++++++++- cache/src/backends/rocksdb.rs | 26 +++++++++++++++++++++++++ cache/src/bin/cache_fs_to_rocksdb.rs | 37 ++++++++++++++++++++++++++++++++++++ cache/src/lib.rs | 5 +++-- 4 files changed, 80 insertions(+), 3 deletions(-) create mode 100644 cache/src/backends/rocksdb.rs create mode 100644 cache/src/bin/cache_fs_to_rocksdb.rs (limited to 'cache/src') diff --git a/cache/src/backends/mod.rs b/cache/src/backends/mod.rs index 6b7dac3..5872255 100644 --- a/cache/src/backends/mod.rs +++ b/cache/src/backends/mod.rs @@ -4,10 +4,23 @@ Copyright (C) 2025 metamuffin */ pub mod filesystem; +pub mod rocksdb; -use anyhow::Result; +use crate::{ + CONF, + backends::{filesystem::Filesystem, rocksdb::Rocksdb}, +}; +use anyhow::{Result, bail}; pub(crate) trait CacheStorage: Send + Sync + 'static { fn store(&self, key: String, value: &[u8]) -> Result<()>; fn read(&self, key: &str) -> Result>>; } + +pub fn init_backend() -> Result> { + Ok(match CONF.driver.as_str() { + "filesystem" => Box::new(Filesystem::new(&CONF)), + "rocksdb" => Box::new(Rocksdb::new(&CONF)?), + _ => bail!("unknown driver"), + }) +} diff --git a/cache/src/backends/rocksdb.rs b/cache/src/backends/rocksdb.rs new file mode 100644 index 0000000..183664f --- /dev/null +++ b/cache/src/backends/rocksdb.rs @@ -0,0 +1,26 @@ +/* + This file is part of jellything (https://codeberg.org/metamuffin/jellything) + which is licensed under the GNU Affero General Public License (version 3); see /COPYING. + Copyright (C) 2025 metamuffin +*/ + +use crate::{Config, backends::CacheStorage}; +use anyhow::Result; +use rocksdb::DB; + +pub struct Rocksdb(DB); + +impl Rocksdb { + pub fn new(config: &Config) -> Result { + Ok(Self(rocksdb::DB::open_default(config.path.clone())?)) + } +} + +impl CacheStorage for Rocksdb { + fn store(&self, key: String, value: &[u8]) -> Result<()> { + Ok(self.0.put(key, value)?) + } + fn read(&self, key: &str) -> Result>> { + Ok(self.0.get(key)?) + } +} diff --git a/cache/src/bin/cache_fs_to_rocksdb.rs b/cache/src/bin/cache_fs_to_rocksdb.rs new file mode 100644 index 0000000..0a3b43d --- /dev/null +++ b/cache/src/bin/cache_fs_to_rocksdb.rs @@ -0,0 +1,37 @@ +/* + This file is part of jellything (https://codeberg.org/metamuffin/jellything) + which is licensed under the GNU Affero General Public License (version 3); see /COPYING. + Copyright (C) 2025 metamuffin +*/ + +use anyhow::{Result, bail}; +use rocksdb::DB; +use std::{env::args, fs::File, io::Read, path::Path}; + +fn main() -> Result<()> { + let in_path = args().nth(1).unwrap(); + let out_path = args().nth(2).unwrap(); + let db = DB::open_default(out_path)?; + if !in_path.ends_with("/") { + bail!("path needs to end with /") + } + traverse(&db, &in_path, in_path.as_ref())?; + Ok(()) +} + +fn traverse(db: &DB, prefix: &str, path: &Path) -> Result<()> { + if path.is_dir() { + for e in path.read_dir()? { + traverse(db, prefix, &e?.path())?; + } + } + if path.is_file() { + let key = path.to_string_lossy(); + let key = key.strip_prefix(prefix).unwrap(); + let mut value = Vec::new(); + File::open(path)?.read_to_end(&mut value)?; + println!("{key}"); + db.put(key, value)?; + } + Ok(()) +} diff --git a/cache/src/lib.rs b/cache/src/lib.rs index 20e1424..d68266f 100644 --- a/cache/src/lib.rs +++ b/cache/src/lib.rs @@ -6,7 +6,7 @@ mod backends; mod helper; -use crate::backends::{CacheStorage, filesystem::Filesystem}; +use crate::backends::{CacheStorage, init_backend}; use anyhow::{Context, Result, anyhow}; use log::{info, warn}; use serde::{Deserialize, Serialize}; @@ -26,6 +26,7 @@ pub use helper::{EscapeKey, HashKey}; #[derive(Debug, Deserialize)] pub struct Config { + driver: String, path: PathBuf, max_in_memory_cache_size: usize, } @@ -49,7 +50,7 @@ static CACHE_STORE: OnceLock> = OnceLock::new(); pub fn init_cache() -> Result<()> { CACHE_STORE - .set(Box::new(Filesystem::new(&CONF))) + .set(init_backend().context("cache backend")?) .map_err(|_| ()) .unwrap(); Ok(()) -- cgit v1.3