微软通过Cosmos DB向MongoDB和Cassandra发起挑战
点击关注 InfoQ,置顶公众号
接收程序员的 8 点技术早餐
第一步是拥抱竞争对手的标准。在八九十年代,这意味着能够读写他们的文件格式。例如,MS Word 需要能够完美地打开、修改和保存 WordPerfect 文档。否则,对于当时是主流的 WordPerfect,其用户甚至都不会考虑试一下 Word。
在 NoSQL 数据库领域,需要拥抱的标准是 API。和关系型数据库至少会支持 ANSI SQL 标准不同,每一种 NoSQL 数据库都有自己的一套 API 和相应的驱动。因此,理论上讲,用户会被特定的产品绑定,不付出很高的代价重写,就无法切换到其他的产品。
通过拥抱当前较为流行的数据库的 API 和驱动,微软的 Cosmos DB 解决了这个供应商锁定问题。我们这里所说的“拥抱”是一种纯字面的理解。
当配置 Cosmos DB 实例时,需要选择一种 API 类型,选项包括:
SQL (实际上是旧有的 Azure DocumentDB)
Gremlin,一种图数据库
MongoDB
Azure Table
Cassandra
如果用户选择 MongoDB 作为使用的 API,那么他就可以使用已有的 MongoDB 驱动,而不是一个类似 MongoDB 驱动的驱动。而且,微软的文档会直接把用户导向官方的 MongoDB 驱动,包括 Node.js、.NET、Java 等。类似地,对于 Gremlin 和 assandra,用户在使用 Gremlin 或 Cassandra 模式时,也是使用各自相应的驱动和 Cosmos DB 通信。
理论上,这意味着 Azure Cosmos DB 是其他 NoSQL 数据库的替代品。
由于上述所有的第三方数据库都是免费 / 开源的,所以除了托管之外,微软还必须提供更多的功能。否则,当其他数据库提供了性能更好或者价格更低的兼容云的解决方案时,用户就会立马切换回去。
这就轮到微软的其他 Azure 产品发挥作用了。Cosmos DB 可以和 Apache Spark 或 Apache Kafka 等开源产品集成,也可以和 Azure Search、Azure Data Factory 和 HDInsight 等专利产品集成。不是扩展文件格式,而是设法扩展用户使用数据库可以完成的工作。
虽然从 MongoDB 的云托管切换到 Cosmos DB 主要是 QA 和操作问题,那么使用其他 Azure 产品会极大地限制用户将来的架构选择。用户需要根据长远规划仔细权衡微软今天提供的便利和功能。
长远来看,NoSQL 的发展还很难预测。一种可能是,发展出一种所有主流 NoSQL 数据库都遵循的标准查询语言,和上世纪 80 年代的 ANSI SQL 一样。另一种可能是,ANSI SQL 继续发展,并最终承担起这个角色。
或者,MongoDB 中已有的 API 变成了事实上的标准,得到了主流供应商的非正式认可,但永远不会得到一个标准组织的正式批准。
同时,任何一种 NoSQL 数据库都不可能一直占据主导地位,因为竞争对手很容易复制他们的 REST API。即使 CosmoDB 成功颠覆了 MongoDB 或 Cassandra 的市场地位,其他数据库 / 云供应商,如亚马逊或谷歌,也可以做同样的事情。
本文翻译已获授权,原文链接:
http://www.infoq.com/news/2018/03/CosmosDB
关注公众号:拾黑(shiheibook)了解更多
[广告]赞助链接:
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
随时掌握互联网精彩
- 1 确保受灾群众温暖过冬 7919007
- 2 女童高山走失3天 父亲悬赏100万寻人 7900493
- 3 夫妻76万买260平复式花60万装修 7893357
- 4 2025春运细微处见暖意 7790097
- 5 李一桐唐装美人太惊艳了 7697531
- 6 夫妻凌晨4点到家 父母放鞭炮迎接 7535103
- 7 综艺“恶人谷”正在榨干演员 7494359
- 8 特朗普:拜登忘了赦免自己 7346269
- 9 公安网安|净网2024取得显著成效 7203460
- 10 310家公司发“过年红包”3400多亿 7125017