Infinitree加密嵌入式数据库

联合创作 · 2023-10-01 02:29

Infinitree 是具有 3 层缓存的可扩展和加密嵌入式数据库,使用 Rust 编写。


主要特性



  • 默认线程安全

  • 透明式处理热/温/冷存储,目前支持 S3 兼容的后端

  • 可以使用Iterator特征查询而无需完全加载的版本化数据结构

  • 加密所有磁盘数据,仅在使用时解密

  • 关注性能,以及性能/内存使用的灵活折中

  • 可扩展自定义数据类型和存储策略

  • 方便与云 worker 和 KMS 集成,用于进行访问控制


使用示例



use infinitree::{
Infinitree,
Index,
Key,
anyhow,
backends::Directory,
fields::{Serialized, VersionedMap, LocalField},
};
use serde::{Serialize, Deserialize};

#[derive(Serialize, Deserialize)]
pub struct PlantHealth {
id: usize,
air_humidity: usize,
soil_humidity: usize,
temperature: f32
}

#[derive(Index, Default, Clone)]
pub struct Measurements {
// rename the field when serializing
#[infinitree(name = "last_time")]
_old_last_time: Serialized<String>,

#[infinitree(name = "last_time2")]
last_time: Serialized<usize>,

// only store the keys in the index, not the values
#[infinitree(strategy = "infinitree::fields::SparseField")]
measurements: VersionedMap<usize, PlantHealth>,

// skip the next field when loading & serializing
#[infinitree(skip)]
current_time: usize,
}

fn main() -> anyhow::Result<()> {
let mut tree = Infinitree::<Measurements>::empty(
Directory::new("/storage")?,
Key::from_credentials("username", "password")?
);

tree.index().measurements.insert(1, PlantHealth {
id: 0,
air_humidity: 50,
soil_humidity: 60,
temperature: 23.3,
});

*tree.index().last_time.write() = 1;
tree.commit("first measurement! yay!");
Ok(())
}
浏览 17
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报