From 5d76db8f19d1d1a69728a87e2967811d634520b3 Mon Sep 17 00:00:00 2001
From: Jason Volk <jason@zemos.net>
Date: Sun, 28 Apr 2024 13:09:26 -0700
Subject: [PATCH] add configuration for rocksdb direct-io enablement

Signed-off-by: Jason Volk <jason@zemos.net>
---
 conduwuit-example.toml       | 4 ++++
 src/config/mod.rs            | 4 ++++
 src/database/rocksdb/opts.rs | 6 ++++--
 3 files changed, 12 insertions(+), 2 deletions(-)

diff --git a/conduwuit-example.toml b/conduwuit-example.toml
index 03029dd5d..cb6d0402f 100644
--- a/conduwuit-example.toml
+++ b/conduwuit-example.toml
@@ -384,6 +384,10 @@ allow_profile_lookup_federation_requests = true
 # Defaults to false
 #rocksdb_optimize_for_spinning_disks = false
 
+# Enables direct-io to increase database performance. This is enabled by default. Set this option to false if the
+# database resides on a filesystem which does not support direct-io.
+#rocksdb_direct_io = true
+
 # RocksDB log level. This is not the same as conduwuit's log level. This is the log level for the RocksDB engine/library
 # which show up in your database folder/path as `LOG` files. Defaults to error. conduwuit will typically log RocksDB errors as normal.
 #rocksdb_log_level = "error"
diff --git a/src/config/mod.rs b/src/config/mod.rs
index 315e1fb48..161aa4b5a 100644
--- a/src/config/mod.rs
+++ b/src/config/mod.rs
@@ -218,6 +218,8 @@ pub(crate) struct Config {
 	pub(crate) rocksdb_log_time_to_roll: usize,
 	#[serde(default)]
 	pub(crate) rocksdb_optimize_for_spinning_disks: bool,
+	#[serde(default = "true_fn")]
+	pub(crate) rocksdb_direct_io: bool,
 	#[serde(default = "default_rocksdb_parallelism_threads")]
 	pub(crate) rocksdb_parallelism_threads: usize,
 	#[serde(default = "default_rocksdb_max_log_files")]
@@ -703,6 +705,8 @@ fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
 				&self.rocksdb_optimize_for_spinning_disks.to_string(),
 			),
 			#[cfg(feature = "rocksdb")]
+			("RocksDB Direct-IO", &self.rocksdb_direct_io.to_string()),
+			#[cfg(feature = "rocksdb")]
 			("RocksDB Parallelism Threads", &self.rocksdb_parallelism_threads.to_string()),
 			#[cfg(feature = "rocksdb")]
 			("RocksDB Compression Algorithm", &self.rocksdb_compression_algo),
diff --git a/src/database/rocksdb/opts.rs b/src/database/rocksdb/opts.rs
index 6d2308999..8e90bec66 100644
--- a/src/database/rocksdb/opts.rs
+++ b/src/database/rocksdb/opts.rs
@@ -36,8 +36,10 @@ pub(crate) fn db_options(config: &Config, env: &mut Env, row_cache: &Cache, col_
 
 	// IO
 	opts.set_manual_wal_flush(true);
-	opts.set_use_direct_reads(true);
-	opts.set_use_direct_io_for_flush_and_compaction(true);
+	if config.rocksdb_direct_io {
+		opts.set_use_direct_reads(true);
+		opts.set_use_direct_io_for_flush_and_compaction(true);
+	}
 	if config.rocksdb_optimize_for_spinning_disks {
 		// speeds up opening DB on hard drives
 		opts.set_skip_checking_sst_file_sizes_on_db_open(true);
-- 
GitLab