写点什么

Cosmos DB:全球分布式数据库

  • 2017-11-13
  • 本文字数:964 字

    阅读完需:约 3 分钟

今天是 PASS 2017 峰会的第二日,上午首个主题演讲是 Microsoft Cosmos DB 组产品经理 Rimma Nehme 对 Azure Cosmos DB 的介绍。Nehme 以丰富的信息量和快速的表达,介绍了 Microsoft 设计和构建 Cosmos DB 所用的方法。

在开始介绍 Cosmos DB 之前,Nehme 探讨了一些影响设计团队考虑的市场趋势。据 Nehme 介绍,全世界 90% 的数据都是在近两年间创造的。从 2010 起算的 10 年期间,全世界的数据量有望增长 50 到 100 倍。如果将适合该趋势的需求与计算应该接近数据的理念相结合,那么传统的“俗世”数据库从技术上并不适于应对这种复杂的局面。

“佛罗伦萨计划”是 Microsoft 为应对这种趋势而提出的一个解决方案,它是由 Dharma Shukla 启动的。选择佛罗伦萨为项目名称的背景是,Shukla 在该城市度假时提交了项目的首个代码。从更宽泛的意义上看,佛罗伦萨是欧洲文艺复兴开始的中心,这符合当今计算机世界对数据的需求将会爆发这一预测。

此后,“佛罗伦萨计划”演变为 Azure Cosmos DB 产品。项目开始时的目标取决于 Bing、Xbox Live 等微软内部客户的需求。至 2010 年,项目的需求发展为:

  1. 全球分布的一站式解决方案;
  2. 全球范围内 99% 的低延迟保证;
  3. 区域和全球范围内的高可用性保证;
  4. 确保一致性;
  5. 全球范围内通量和存储的弹性扩展,并可随时按需提供服务;
  6. 全面 SLA(可用性、延迟、通量、一致性);
  7. 低运维代价;
  8. 迭代和查询,无需关心具体的模式和索引管理;
  9. 提供一系列的可选数据模型和 API。

简而言之,Cosmos DB 团队的任务是在确定如何构建全球分布式云数据库的同时,也满足 Microsoft 内部客户的需求。Cosmos DB 的成功使得其成为 Azure 内部的“首环”(Ring 0)服务,即一旦有新的 Azure 地理区域建立,Cosmos DB 就是该区域内首批提供的服务之一。从开发人员的角度看,Cosmos 主要使用 C++ 语言编写。

Azure Cosmos DB 提供了五种一致性模型,分别是:强一致性(Strong)、受限无状态一致性(Bounded-stateless)、会话一致性(Session)、前缀一致性(Consistent Prefix)和最终一致性。其中最广泛使用的是会话一致性,它的使用远远领先于第二位的受限无状态一致性。

Nehme 的主题演讲的节奏很快,提供了丰富的信息。想要了解 Cosmos DB 的更多技术细节,可以查看 Dharma Shukla 在今天春季撰写的一篇文章

查看英文原文: Cosmos DB - A Globally Distributed Database

2017-11-13 18:003225
用户头像

发布了 391 篇内容, 共 155.9 次阅读, 收获喜欢 257 次。

关注

评论

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

读书笔记之互联网金融思考一则

石君

金融科技 互联网金融 28天写作

企业需要DevSecOps来保证应用程序的安全

啸天

安全 DevSecOps 应用安全

数字货币合约交易系统软件开发|数字货币合约交易APP开发

系统开发

给自己当前岗位所定义的理想岗位模型

邹小胖

自我思考

第一章 认识产品经理(上)

郭栋

产品经理训练营

高并发场景下如何优化服务器的性能?

冰河

Linux 并发编程 高并发 服务器 性能调优

案例研究之聊聊 QLExpress 源码 (八-2)

小诚信驿站

聊聊架构 28天写作 QLExpress源码 聊聊源码

第一周-胡赵凯-总结

hisun胡

产品经理训练营

道德困境 - 电车难题

石云升

28天写作 道德困境 电车难题

作业-第13周

arcyao

精选算法面试-哈希表II

李孟聊AI

面试 算法 28天写作

有道乐读 x AWS | 云上的少儿图书馆!这个寒假让孩子爱上“乐读”

亚马逊云科技 (Amazon Web Services)

云计算 AWS

前端也要懂机器学习(下)

执鸢者

机器学习 大前端

产品经理岗位调研

发条檀木

产品经理训练营

单例模式作业

Geek_mewu4t

架构师训练营 week13 学习笔记

花果山

第八周命题作业

cc

构师训练营 - 第十三周课后练习

joshuamai

产品经理训练营课后作业-第一周-认识产品经理

.nil?

产品经理训练营

怎样更好地阅读源码?

程序员架构进阶

方法论 开发 源码阅读 提升自我 28天写作

币币撮合交易系统软件开发|币币撮合交易APP开发

系统开发

数字货币交易APP系统开发|数字货币交易软件开发

系统开发

在 AWS 的视角下,正确打开零信任安全模型

亚马逊云科技 (Amazon Web Services)

云计算 AWS

架构师训练营 week13 课后作业

花果山

nodejs中的文件系统

程序那些事

nodejs 文件系统 异步IO 异步编程 程序那些事

STM32通过rosserial接入ROS通讯开发

良知犹存

stm32 ROS

程序员行业半衰期太短,如何保持高效发展?

李忠良

28天写作

第一周-胡赵凯-作业

hisun胡

产品经理训练营

敏捷开发需要内外兼修

Bruce Talk

敏捷开发 Agile

第八周学习心得

cc

AWS Graviton2 | 匠“芯”定制,性能为王

亚马逊云科技 (Amazon Web Services)

云计算 AWS

Cosmos DB:全球分布式数据库_.NET_Jeff Martin_InfoQ精选文章