分布式数据库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文件,为该绑定提供指定的目标。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,874评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,102评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,676评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,911评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,937评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,935评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,860评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,660评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,113评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,363评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,506评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,238评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,861评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,486评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,674评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,513评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,426评论 2 352

推荐阅读更多精彩内容

  • 注意:由于idfa会出现取不到的情况,故绝不可以作为业务分析的主id,来识别用户。 因此,IDFA就是用来跟踪广告...
    普通青年阅读 168评论 0 0
  • 转载2017年11月01日 09:54:03 2595 RabbitMQ 即一个消息队列,主要是用来实现应用程序的...
    杨传池chris阅读 6,350评论 1 0
  • 本文是参考《【区块链】DOCKER部署量子链私有网络环境以及部署智能合约实践》和比特币的命令行操作,来通过量子链源...
    oracle3阅读 1,160评论 2 1
  • 我从远方来,恰好你在,恰好你也从远方来;我说,最终回远方去,恰好你说你也回去。 我想去聆听你长发的忧伤,然后再向...
    梦易阅读 475评论 1 1
  • 花说 我要寂寞 不想陪伴虫鸟的漂泊 叶说 我要漂泊 不想长成年轮的枷锁 蒲公英说 我要枷锁 不想追逐风的偏颇 你说...
    thornmia阅读 333评论 0 0