simplify db ThreadMode typedef
Signed-off-by: Jason Volk <jason@zemos.net>
This commit is contained in:
parent
7db8478dc0
commit
35049c94de
1 changed files with 8 additions and 6 deletions
|
@ -9,7 +9,7 @@ use conduit::{debug, error, info, warn, Result, Server};
|
||||||
use rocksdb::{
|
use rocksdb::{
|
||||||
backup::{BackupEngine, BackupEngineOptions},
|
backup::{BackupEngine, BackupEngineOptions},
|
||||||
perf::get_memory_usage_stats,
|
perf::get_memory_usage_stats,
|
||||||
BoundColumnFamily, Cache, ColumnFamilyDescriptor, DBCommon, DBWithThreadMode as Db, Env, MultiThreaded, Options,
|
BoundColumnFamily, Cache, ColumnFamilyDescriptor, DBCommon, DBWithThreadMode, Env, MultiThreaded, Options,
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
@ -24,10 +24,12 @@ pub struct Engine {
|
||||||
opts: Options,
|
opts: Options,
|
||||||
env: Env,
|
env: Env,
|
||||||
cfs: Mutex<HashSet<String>>,
|
cfs: Mutex<HashSet<String>>,
|
||||||
pub(crate) db: Db<MultiThreaded>,
|
pub(crate) db: Db,
|
||||||
corks: AtomicU32,
|
corks: AtomicU32,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub(crate) type Db = DBWithThreadMode<MultiThreaded>;
|
||||||
|
|
||||||
impl Engine {
|
impl Engine {
|
||||||
pub(crate) fn open(server: &Arc<Server>) -> Result<Arc<Self>> {
|
pub(crate) fn open(server: &Arc<Server>) -> Result<Arc<Self>> {
|
||||||
let config = &server.config;
|
let config = &server.config;
|
||||||
|
@ -49,13 +51,13 @@ impl Engine {
|
||||||
let load_time = std::time::Instant::now();
|
let load_time = std::time::Instant::now();
|
||||||
if config.rocksdb_repair {
|
if config.rocksdb_repair {
|
||||||
warn!("Starting database repair. This may take a long time...");
|
warn!("Starting database repair. This may take a long time...");
|
||||||
if let Err(e) = Db::<MultiThreaded>::repair(&db_opts, &config.database_path) {
|
if let Err(e) = Db::repair(&db_opts, &config.database_path) {
|
||||||
error!("Repair failed: {:?}", e);
|
error!("Repair failed: {:?}", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
debug!("Listing column families in database");
|
debug!("Listing column families in database");
|
||||||
let cfs = Db::<MultiThreaded>::list_cf(&db_opts, &config.database_path).unwrap_or_default();
|
let cfs = Db::list_cf(&db_opts, &config.database_path).unwrap_or_default();
|
||||||
|
|
||||||
debug!("Opening {} column family descriptors in database", cfs.len());
|
debug!("Opening {} column family descriptors in database", cfs.len());
|
||||||
let cfds = cfs
|
let cfds = cfs
|
||||||
|
@ -65,9 +67,9 @@ impl Engine {
|
||||||
|
|
||||||
debug!("Opening database...");
|
debug!("Opening database...");
|
||||||
let res = if config.rocksdb_read_only {
|
let res = if config.rocksdb_read_only {
|
||||||
Db::<MultiThreaded>::open_cf_for_read_only(&db_opts, &config.database_path, cfs.clone(), false)
|
Db::open_cf_for_read_only(&db_opts, &config.database_path, cfs.clone(), false)
|
||||||
} else {
|
} else {
|
||||||
Db::<MultiThreaded>::open_cf_descriptors(&db_opts, &config.database_path, cfds)
|
Db::open_cf_descriptors(&db_opts, &config.database_path, cfds)
|
||||||
};
|
};
|
||||||
|
|
||||||
let db = res.or_else(or_else)?;
|
let db = res.or_else(or_else)?;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue