分布式数据库FoundationDB开源了
编者:最近,苹果公司宣布将旗下数据库产品FoundationDB核心开源,以建立一个开放的社区。该开源项目已公布在Github上。FoundationDB是“一个能在多集群服务器上存放大规模结构化数据的分布式数据库”。该数据库系统专注于高性能、高可扩展性、和不错的容错能力。
FoundationDB是由戴夫·罗森塔尔(Dave Rosenthal)、戴夫·谢勒(Dave Scherer)、和尼克拉维泽(Nick Lavezzo)于2009年开发的,旨在建立一个符合ACID约束的NoSQL数据库,ACID是一种即使在发生错误时也保证数据完整性的数据库机制。2015 年苹果公司收购了数据提供商 FoundationDB,目的是为了提升旗下 App Store、iTunes Connect、 iTunes 服务在云端的服务器技术。FoundationDB 随之从开源变为闭源。
FoundationDB官网的声明指出,经过多年的开发和生产环境使用FoundationDB 已经非常成熟,其将成为下一代分布式数据库的基石。通过开源FoundationDB,我们的目标是建设一个开放的社区,所有重大开发都将在开源环境中进行。
FoundationDB是一个分布式数据库,用于处理大量的、跨商用服务器集群的结构化数据。它使用有序的键值(key-value)存储方式,并能让所有操作具有ACID事务属性。特别适合读/写频繁的操作,而且对于“写”密集的操作也具有极好的性能。用户可以使用绑定的API与数据库进行交互。
更多信息可以访问foundationdb.org。
文档
相关文档可以在https://apple.github.io/foundationdb/中找到。文档包括API的使用、设计理念的背景信息以及扩展的应用示例。文档是根据本库的源码创建的。
论坛
欢迎加入FoundationDB论坛,参与对FoundationDB项目的讨论和交流。我们希望FoundationDB能够成为一个伟大的项目,因此建立了一套行为准则来规范互动模式。
图:FoundationDB论坛
贡献您的力量
可以对FoundationDB代码库贡献代码,在论坛上分享使用经验和见解,或者对使用FoundationDB的项目做出贡献。详情请参阅贡献指南。
入门
二进制包下载
开发人员可以很容易地通过下载和安装二进制包,轻松启动FoundationDB。
请查看 下载页面 (https://www.foundationdb.org/download/) 中软件包列表。
图:FoundationDB下载页面
源码编译
如果开发人员没有找到相应操作系统的二进制包,或者想深入了解代码,可以从源码编译开始。
macOS
1、在Mac上检出(check out)你的分支库
2、安装Xcode命令行工具
3、下载Boost 1.52版本(https://sourceforge.net/projects/boost/files/boost/1.52.0/)
4、设置BOOSTDIR环境变量,指明Boost安装的位置
5、安装Mono
6、安装JDK 。FoundationDB 当前要求 Java 8。
7、回到foundationdb 检出分支库的目录
8、运行make。
Linux
1、安装Docker
2、使用build源目录中的文件Dockerfile构建Linux的docker image。
3、检出(check out)foundationdb分支库
4、运行docker镜像,命令包含foundationdb分支库的安装加载(Docker Mounts)目录。
docker
run-it-v'/local/dir/path/foundationdb:/docker/dir/path/foundationdb'/bin/bash
5、回到包含foundationdb分支库的安装加载目录。
cd /docker/dir/path/foundationdb
6、运行make。
这种方式将实现foundationdb服务器端(fdbserver)程序和Python的绑定。如果要绑定其他语言,则需要安装要相应语言的运行时(runtime)。每个绑定都有一个.mk文件,为该绑定提供指定的目标。