电子说
Cannonball 是一个用 Rust 构建 QEMU 插件的框架!您可以在 C 语言的 QEMU TCG 插件中执行的任何操作,都可以使用cannonball。编写以最小的开销和尽可能多的功能运行的插件!
这里提供了几个例子!
jaivana
一个简单的跟踪器,将一组可配置的事件记录到文件或标准输出中。
mons meg
一个跟踪器,记录与 Jaivana 相同的事件,但使用 Tokio 在异步环境中运行跟踪,通过 UNIX 套接字而不是匿名管道与主机进行通信。 看看它们,它们是学习如何使用这个框架的最佳方式。
安装 只需将其添加到您的 Cargo.toml:
cannonball = "0.2.4"
J
aivana 的演示例子: https://github.com/novafacing/cannonball/tree/main/examples/jaivana
整体设计参考LevelDB,旨在作为NewSQL数据库的存储引擎
支持嵌入式/单机存储/远程调用等多应用场景
以Kiss作为开发理念,设计以简单而高效为主导
实现MVCC以支持ACID
性能,BenchMark 读取吞吐量约为 Sled 的两倍,且大数据量下的读取顺序平均延迟为 1μs 左右
远程连接使用ProtoBuf实现,支持多语言通信
极小内存占用(占用/大量冷数据)
安全读取
kip_db = "0.1.1-alpha.0"
cargo build
cargo build --release
cargo test
cargo bench
docker build -t kould/kip-db:v1 .
docker run kould/kip-db:v1
/// 指定文件夹以开启一个KvStore let kip_db = LsmStore::open("/welcome/kip_db").await?; // 插入数据 kip_db.set(&b"https://github.com/KKould/KipDB", Bytes::from(&b"your star plz"[..])).await?; // 获取数据 let six_pence = kip_db.get(&b"my deposit").await?; // 已占有硬盘大小 let just_lot = kip_db.size_of_disk().await? // 已有数据数量 let how_many_times_you_inserted = kip_db.len().await?; // 删除数据 kip_db.remove(&b"ex girlfriend").await?; // 创建事务 let mut transaction = kip_db.new_transaction().await?; // 插入数据至事务中 transaction.set(&b"this moment", Bytes::from(&b"hope u like it"[..])); // 删除该事务中key对应的value transaction.remove(&b"trouble")?; // 获取此事务中key对应的value let ping_cap = transaction.get(&b"dream job")?; // 提交事务 transaction.commit().await?; // 创建持久化数据迭代器 let guard = kip_db.iter().await?; let mut iterator = guard.iter()?; // 获取下一个元素 let hello = iterator.next_err()?; // 移动至第一个元素 let world = iterator.seek(Seek::Last)?; // 强制数据刷入硬盘 kip_db.flush().await?;
全部0条评论
快来发表一下你的评论吧 !