Cannonball Rust 构建的 QEMU 插件的框架
Cannonball 是一个用 Rust 构建 QEMU 插件的框架!您可以在 C 语言的 QEMU TCG 插件中执行的任何操作,都可以使用cannonball。编写以最小的开销和尽可能多的功能运行的插件!
例子
这里提供了几个例子!
- jaivana
一个简单的跟踪器,将一组可配置的事件记录到文件或标准输出中。
- mons meg
一个跟踪器,记录与 Jaivana 相同的事件,但使用 Tokio 在异步环境中运行跟踪,通过 UNIX 套接字而不是匿名管道与主机进行通信。 看看它们,它们是学习如何使用这个框架的最佳方式。
安装
安装 只需将其添加到您的 Cargo.toml:
代码语言:javascript复制cannonball = "0.2.4"
Jaivana 的演示例子: https://github.com/novafacing/cannonball/tree/main/examples/jaivana
kiddb 基于 Rust 的嵌入式存储引擎
整体设计参考LevelDB,旨在作为NewSQL数据库的存储引擎
- 支持嵌入式/单机存储/远程调用等多应用场景
- 以Kiss作为开发理念,设计以简单而高效为主导
- 实现MVCC以支持ACID
- 性能,BenchMark 读取吞吐量约为 Sled 的两倍,且大数据量下的读取顺序平均延迟为 1μs 左右
- 远程连接使用ProtoBuf实现,支持多语言通信
- 极小内存占用(占用/大量冷数据)
- 安全读取
组件引入
代码语言:javascript复制kip_db = "0.1.1-alpha.0"
代码
代码编译
代码语言:javascript复制cargo build
代码编译(正式环境)
代码语言:javascript复制cargo build --release
单元测试
代码语言:javascript复制cargo test
性能基准测试
代码语言:javascript复制cargo bench
Docker镜像编译
编译镜像
代码语言:javascript复制docker build -t kould/kip-db:v1 .
运行镜像
代码语言:javascript复制docker run kould/kip-db:v1
直接调用(基本使用)
代码语言:javascript复制/// 指定文件夹以开启一个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?;
- https://github.com/KipData/KipDB