限时领|《AI 百问百答》专栏课+实体书(包邮)! 了解详情
写点什么

专访 FoundationDB 联合创始人 Nick Lavezzo

  • 2013-01-20
  • 本文字数:1759 字

    阅读完需:约 6 分钟

FoundationDB 是一个数据库,它保证了 ACID,同时还具有通常只有 NoSQL 数据库才有的高性能和可用性。InfoQ 对该项目的创始人之一 Nick Lavezzo 做了独家专访,从他那里我们获得了更多与该项目相关的内容。

InfoQ: 我们了解到为了避开 CAP 定理宣称的限制,实现 ACID 和可扩展性,FoundationDB 使用了两种不同类型的节点进行读写操作,事实是这样吗?你可以详细地解释一下这个架构吗?

Nick: FoundationDB 并没有避开 CAP 定理;它只不过是采用了非传统的方式(对 NoSQL 而言)在网络分区间维护一致性。但是构建一个分布式的、完全一致的数据库很难;因此,为了让事情更简单,我们使用不同的服务器担当不同的角色。其中,最重要的两个角色是事务服务器和存储服务器。事务服务器负责检查发生的冲突,以保证 ACID。存储服务器负责存储大量的有序键 - 值对,同时为事务服务器批准的读写请求提供服务。当然,在一个单独的物理机器上或者一个较小的集群中,这些角色可能重叠,一台电脑可以同时做多个任务。想要获取更多的信息可以在我们的网站上查看更加详细的解释

InfoQ:你提到 FoundationDB 和一个“分层的”生态系统将会有开源和商业两个版本——对于爱好者而言,现在能够获取它们的源码吗?

Nick:我们一直在致力于构建核心数据库,但是我们对内部层的清理和文档化工作做的还不够,因此还不能公开对外发布(不过在我们的 alpha 测试者的要求下,现在这一层已经可以访问)。在往 beta 版进发的过程中,我们计划为层创建公共仓库。这些层一方面是揭示高层次数据模型的优秀工具,另一方面也展示了基于 FoundationDB 的有序键 - 值对 API 构建强大的应用是多么地容易。现在对层 / 应用程序代码示例有兴趣的人,可以在这里查看一些示例

InfoQ:你提到一个构建在 C++ 之上的新语言 Flow,同时还提供了工具——可以分享一些相关的细节么?

Nick:我们已经在网站上发布了一段新内容,解释了 Flow 以及构建它的目的。

InfoQ: 现在有人开始使用 FoundationDB 构建应用程序了么?

Nick:我们的测试员已经在构建基于 FoundationDB 的应用程序了,但我并不认为这是你期望的答案。你的意思应该是指生产环境中的应用程序,例如在它上面运行业务。FoundationDB 现在正在 Alpha 阶段。在我们推出快照备份功能之前,也就是几周之前,我们不推荐任何人在生产环境中使用它。无论一个系统如何容灾,如果有人意外地(或者故意地)删除数据库中的数据,你都需要一个外部备份来恢复生产环境的应用程序。现在我们有了这个功能,所以我们正在和一些 alpha 测试者们一起将它应用于一些生产环境中的项目上。

InfoQ:FoundationDB 现在或者将来能够支持全球分布式的数据库节点么,就像 Google Spanner 那样?如果是,它将如何实现?

Nick:是的。FoundationDB 就是为了在本地和跨数据中心的集群中使用而设计的。在多数据中心配置环境中运行时,FoundationDB 能够感知网络拓扑并做出智能的决定,例如在不同的数据中心存储数据副本。和 Google Spanner 一样,FoundationDB 并不会使用全球各地所有的数据中心创建一个单一的、全局的数据库;相反,它会创建一个能够在几个临近的数据中心上高效运行的数据库。(通过在全球各地自动移动数据可以加快数据读取速度,但是,数据写入则是一个更加困难且特定于应用程序的工作。Spanner 和 FoundationDB 都没有彻底解决这个问题。)

我们如何实现它呢?我认为解释它最简单的方式就是,所有像 FoundationDB 或者 Spanner 这样的系统都会有一个复杂的保障层,该层和其他层一起保持系统正确。Spanner 的实现方式是构建一个独立的“全局变量”:时间。集群中的任何一个节点都能够对它进行强引用。例如,如果计算机 A 更新数据,计算机 B 读取数据,Spanner 的 TrueTime 能够保证:如果 B 的读取操作发生在 A 的写入操作之后,那么 B 看到的一定是修改后的值。FoundationDB 使用一种不同的策略:它使用一个名为 Paxos 的算法(我们的“全局变量”)存储少量的信息,并从中构建其它的保证和引用,而不是依靠时钟。

英文原文地址 Interview With Nick Lavezzo, Co-Founder of FoundationDB


感谢杨赛对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2013-01-20 07:471781
用户头像

发布了 321 篇内容, 共 127.9 次阅读, 收获喜欢 19 次。

关注

评论

发布
暂无评论
发现更多内容

2021 “科创中国”开源创新榜单公布,优麒麟荣登两榜!

优麒麟

Linux 开源 开源社区 优麒麟

创建公司内部文档的入门指南

小炮

工作效率 企业管理 企业管理软件

融合通信常见问题2月刊 | 云信小课堂

网易云信

音视频 融合通信

澜起科技加入,龙蜥社区再迎领先的芯片设计厂商

OpenAnolis小助手

Linux 开源 操作系统 生态 龙蜥社区

【技术分享】历经16年猪八戒网如何成功实现双活流量架构

八戒技术团队

架构

网络安全kali渗透学习 web渗透入门 使用msf渗透攻击Win7主机并远程执行命令

学神来啦

网络安全 Web 渗透 kali kali Linux

2023届校园招聘正式开启!OceanBase 想和你在这个春天约一场面试

OceanBase 数据库

招聘 校园招聘 oceanbase

OceanBase 社区版 OCP 功能解读

OceanBase 数据库

分布式 OceanBase 社区版 工具家族

墨天轮国产数据库沙龙 | 许力:阿里云原生Lindorm TSDB数据库,驱动工业IT&OT超融合数字化系统升级

墨天轮

数据库 阿里云 tsdb

HertzBeat赫兹跳动v1.0.beta.4 发布, 易用友好的高性能监控告警系统

TanCloud探云

开源 APM 监控 监控系统 监控告警

开讲了!龙蜥社区走进北大课堂

OpenAnolis小助手

开源 操作系统 龙蜥社区 北京大学 走进高校

Serverless常见的应用设计模式

亚马逊云科技 (Amazon Web Services)

Serverless 架构

在线Excel文件解析转换成JSON格式

入门小站

工具

招聘宣讲会|Rust 如何为量化行业加速赋能?

非凸科技

ironSource 新功能发布,开发者可在同一会话中实时调整广告策略

极客天地

Linux之crontab命令

入门小站

Linux

揭秘视频千倍压缩背后的技术原理之环路滤波

拍乐云Pano

音视频 RTC 视频编码 音视频开发 视频压缩

一文带你认识 SOFARegistry 之基础架构篇

SOFAStack

开源 架构 注册中心 SOFA

白话大数据 | 从买菜这件小事来聊聊数据仓库

星环科技

前端架构三大巨头之一Angular | 深度讲解

云智慧AIOps社区

开源 前端 Web angular 数据源

【C语言】数据类型存储、原码,反码,补码

謓泽

C语言 补码 原码 反码 3月月更

与容器服务 ACK 发行版的深度对话第二弹:如何借助 hybridnet 构建混合云统一网络平面

阿里巴巴云原生

阿里云 云原生 ACK Distro

Rainbond 5.6 版本发布,增加多种安装方式,优化拓扑图操作体验

北京好雨科技有限公司

直播带练 | 30 分钟用阿里云容器服务和容器网络文件系统搭建 WordPress 网站

阿里巴巴云原生

阿里云 云原生 课程 容器服务 直播回放

cdr2022序列号CorelDRAW2022绿色密钥

茶色酒

CorelDRAW 2022

火山引擎、阿里云、腾讯云联合发布"超低延时"直播技术标准

字节跳动视频云技术团队

音视频

系统学习 TypeScript(五)——联合类型

编程三昧

typescript 前端 3月月更 联合类型

【BBC learningenglish】with Tango

IT蜗壳-Tango

IT蜗壳教学 3月月更 Tango English

ToB月报丨二月融资总金额超152亿元;「东数西算」国家工程全面启动

ToB行业头条

Serverless 底座的持续创新

亚马逊云科技 (Amazon Web Services)

Serverless 架构

基于XuperChain的区块链项目从0到N

刘旭东

区块链 XuperChain

专访FoundationDB联合创始人Nick Lavezzo_大数据_Roopesh Shenoy_InfoQ精选文章