-
Notifications
You must be signed in to change notification settings - Fork 51
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use parity-db in current Dockerfiles (#455)
* Use redb and in Dockerfiles The motivation for redb was to remove the multiple rocksdb compile times from CI. * Correct feature flagging of coordinator and message-queue in Dockerfiles * Correct message-queue DB type alias * Use consistent table typing in redb * Correct rebase artifacts * Correct removal of binaries feature from message-queue * Correct processor feature flagging * Replace redb with parity-db It still has much better compile times yet doesn't block when creating multiple transactions. It also is actively maintained and doesn't grow our tree. The MPT aspects are irrelevant. * Correct stray Redb * clippy warning * Correct txn get
- Loading branch information
1 parent
d1122a6
commit b823413
Showing
18 changed files
with
232 additions
and
149 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
use std::sync::Arc; | ||
|
||
pub use ::parity_db::{Options, Db as ParityDb}; | ||
|
||
use crate::*; | ||
|
||
pub struct Transaction<'a>(&'a Arc<ParityDb>, Vec<(u8, Vec<u8>, Option<Vec<u8>>)>); | ||
|
||
impl Get for Transaction<'_> { | ||
fn get(&self, key: impl AsRef<[u8]>) -> Option<Vec<u8>> { | ||
let mut res = self.0.get(&key); | ||
for change in &self.1 { | ||
if change.1 == key.as_ref() { | ||
res = change.2.clone(); | ||
} | ||
} | ||
res | ||
} | ||
} | ||
impl DbTxn for Transaction<'_> { | ||
fn put(&mut self, key: impl AsRef<[u8]>, value: impl AsRef<[u8]>) { | ||
self.1.push((0, key.as_ref().to_vec(), Some(value.as_ref().to_vec()))) | ||
} | ||
fn del(&mut self, key: impl AsRef<[u8]>) { | ||
self.1.push((0, key.as_ref().to_vec(), None)) | ||
} | ||
fn commit(self) { | ||
self.0.commit(self.1).unwrap() | ||
} | ||
} | ||
|
||
impl Get for Arc<ParityDb> { | ||
fn get(&self, key: impl AsRef<[u8]>) -> Option<Vec<u8>> { | ||
ParityDb::get(self, 0, key.as_ref()).unwrap() | ||
} | ||
} | ||
impl Db for Arc<ParityDb> { | ||
type Transaction<'a> = Transaction<'a>; | ||
fn txn(&mut self) -> Self::Transaction<'_> { | ||
Transaction(self, vec![]) | ||
} | ||
} | ||
|
||
pub fn new_parity_db(path: &str) -> Arc<ParityDb> { | ||
Arc::new(ParityDb::open_or_create(&Options::with_columns(std::path::Path::new(path), 1)).unwrap()) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.