OrioleDB 正在参加 2021 年度 OSC 中国开源项目评选,请投票支持!
OrioleDB 在 2021 年度 OSC 中国开源项目评选 中已获得 {{ projectVoteCount }} 票,请投票支持!
2021 年度 OSC 中国开源项目评选 正在火热进行中,快来投票支持你喜欢的开源项目!
2021 年度 OSC 中国开源项目评选 >>> 中场回顾
OrioleDB 获得 2021 年度 OSC 中国开源项目评选「最佳人气项目」 !
授权协议 PostgreSQL License
开发语言 C/C++ Python Ruby
操作系统 跨平台
软件类型 开源软件
开源组织
地区 不详
投 递 者 白开水不加糖
适用人群 未知
收录时间 2023-07-19

软件简介

OrioleDB 是 PostgreSQL 的全新存储引擎,为该数据库平台带来了现代化的数据库容量、功能和性能。目前正处于公测状态。建议用于实验、测试、基准测试等,但不建议用于生产用途。

OrioleDB 包含一个扩展,它构建在创新的表访问方法框架和其他标准 Postgres 扩展接口的基础上。通过扩展和增强当前的表访问方法,OrioleDB 为未来更强大的存储模型打开了大门,这些模型针对云和现代硬件架构进行了优化。

OrioleDB 目前在标准 PostgreSQL 许可证下分发。

  1. 专为现代硬件而设计。OrioleDB 设计避免了包含数十个和数百个 CPU 核心的现代服务器上的遗留 CPU 瓶颈,从而优化了现代存储技术(例如 SSD 和 NVRAM)的使用。

  2. 减少维护需求。OrioleDB 实现了撤消日志和页面合并的概念,消除了对专用垃圾收集过程的需要。此外,OrioleDB 实现了默认的 64 位事务标识符,从而消除了众所周知且令人痛苦的环绕问题。

  3. 设计为分布式。OrioleDB 实现了行级预写日志并支持并行应用。该日志架构针对基于 raft 共识的复制进行了优化,允许实现主动-主动多主控。

OrioleDB的关键技术差异如下:

  1. 没有缓冲区映射和无锁页面读取。OrioleDB 中的内存页面通过直接链接连接到存储页面。这消除了缓冲区内映射及其相关瓶颈的需要。此外,在 OrioleDB 中,内存页面读取不涉及原子操作。这些设计决策共同将 Postgres 的垂直可扩展性提升到了一个全新的水平。

  2. MVCC 基于UNDO 日志概念。在 OrioleDB 中,旧版本的元组不会导致主存储系统膨胀,而是被逐出到包含撤消链的撤消日志中。页级撤消记录使系统能够轻松地尽快回收已删除元组占用的空间。这些机制与页面合并一起消除了大多数情况下的膨胀。也不需要对表进行专门的 VACUUMing,从而消除了系统性能恶化和数据库中断的重要且常见的原因。

  3. 写时复制检查点和行级 WAL。OrioleDB 利用写时复制检查点,它每时每刻都提供结构一致的数据快照。这对于现代 SSD 很友好,并允许行级 WAL 日志记录。反过来,行级 WAL 日志记录很容易并行化(已完成)、紧凑且适合主动-主动多主机(计划中)。

更多详情可参阅用法架构项目结构文档以及 PostgresBuild 2021 幻灯片。要开始开发,可参阅 OrioleDB 开发快速入门

展开阅读全文

代码

的 Gitee 指数为
超过 的项目

评论

点击引领话题📣 发布并加入讨论🔥
暂无内容
发表了博客
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
发表了问答
{{o.pubDate | formatDate}}

{{formatAllHtml(o.title)}}

{{parseInt(o.replyCount) | bigNumberTransform}}
{{parseInt(o.viewCount) | bigNumberTransform}}
没有更多内容
暂无内容
暂无内容
0 评论
5 收藏
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部