Mercurial > lbo > hg > leveldb-rs
view examples/leveldb-tool/src/main.rs @ 387:2ac6eedcc9dc
db_impl: Use a BufWriter inside LogWriter
Unbuffered write-a-lot with 32768 entries written, first four iterations on a new DB:
usr=0.32 sys=0.12 elap=0.46
usr=0.47 sys=0.12 elap=0.60
usr=0.59 sys=0.11 elap=0.72
usr=0.50 sys=0.15 elap=0.67
Buffered write-a-lot with 32768 entries written, first four iterations on a new DB:
usr=0.22 sys=0.01 elap=0.24 (delta = -0.1/-0.11/-0.22)
usr=0.43 sys=0.03 elap=0.48 (delta = -0.04/-0.09/-0.12)
usr=0.54 sys=0.05 elap=0.62 (delta = -0.05/-0.06/-0.1)
usr=0.42 sys=0.03 elap=0.47 (delta = (-0.08/-0.12/-0.2)
author | Lewin Bormann <lbo@spheniscida.de> |
---|---|
date | Mon, 09 Oct 2017 05:51:43 +0000 |
parents | 36b70e7af130 |
children | 6615d51b1f99 |
line wrap: on
line source
extern crate leveldb_rs; use leveldb_rs::{DB, LdbIterator, Options}; use std::env::args; use std::iter::FromIterator; fn get(db: &mut DB, k: &str) { match db.get(k.as_bytes()) { Some(v) => println!("{} => {}", k, String::from_utf8(v).unwrap()), None => println!("{} => <not found>", k), } } fn put(db: &mut DB, k: &str, v: &str) { db.put(k.as_bytes(), v.as_bytes()).unwrap(); db.flush().unwrap(); } fn delete(db: &mut DB, k: &str) { db.delete(k.as_bytes()).unwrap(); db.flush().unwrap(); } fn iter(db: &mut DB) { let mut it = db.new_iter().unwrap(); while let Some((k, v)) = it.next() { match (String::from_utf8(k), String::from_utf8(v)) { (Ok(sk), Ok(sv)) => println!("{} => {}", sk, sv), (Err(utf8e), Ok(sv)) => println!("{:?} => {}", utf8e.into_bytes(), sv), (Ok(sk), Err(utf8e)) => println!("{} => {:?}", sk, utf8e.into_bytes()), (Err(utf81), Err(utf82)) => { println!("{:?} => {:?}", utf81.into_bytes(), utf82.into_bytes()) } } } } fn main() { let args = Vec::from_iter(args()); if args.len() < 2 { panic!("Usage: {} [get|put|delete|iter] [key] [val]", args[0]); } let mut opt = Options::default(); opt.reuse_logs = true; let mut db = DB::open("tooldb", opt).unwrap(); match args[1].as_str() { "get" => { if args.len() < 3 { panic!("Usage: {} get key", args[0]); } get(&mut db, &args[2]); } "put" => { if args.len() < 4 { panic!("Usage: {} put key val", args[0]); } put(&mut db, &args[2], &args[3]); } "delete" => { if args.len() < 3 { panic!("Usage: {} delete key", args[0]); } delete(&mut db, &args[2]); } "iter" => iter(&mut db), _ => unimplemented!(), } }