0

0

关于Uber选择MySQL的思考

黄舟

黄舟

发布时间:2017-02-07 11:51:36

|

1504人浏览过

|

来源于php中文网

原创

在数据库圈子,大家都知道今年uber干出来一件大事件,把postgresql切换到了mysql,当时社区里一阵喧哗。事情已经过去半年多了,这里我不想去和大家再次讨论这两个关系型数据库那个更好。只是想带着大家思考一下选择的背后。

在该事件中,Uber提出来迁移的一个重要原因是:在大量更新的业务场景下PostgreSQL的IO方面有过多的开销(主要是从存储结构上说明),对于使用SSD或是PCI-E卡的设备基本无法容忍写放大,同时又提出了以下需求:

  • 需要有写缓冲能力,万一持久化到数据库失败时,仍可以稍后重试。

  • 需要通知下游依赖关系的方式,数据变更要能无损的通知出去。

  • 需要二级索引。

  • 系统要足够健壮,可以支持7X24服务。

  • 最重要一点,需要SchemaLess的存储支持

  • 要有能力通过增加服务器动态扩容。增加服务器不但要增加可用的硬盘容量,还要减少系统的响应时间。

Uber针对这些需求也和其它互联网厂家一样,尝试过Cassandra, Riak,MongoDB,也想过自研,但最终选择了MySQL作为存储层。 这里反问一下: MySQL能满足上面的需求吗? 例如:

  • SchemaLess 存储支持

  • 写缓冲能力,较快的故障切换

  • 较好的扩容能力

大家的印象里第一条 Schemaless都可以把MySQL秒了,但从文章里看 Uber技术负责人:Jakob Thomsen 最终使用了MySQL做Schemaless存储方案。我的神啊,大家没看错,没看错,就是使用的MySQL做的schemaless存储方案。

带着好奇心驱动,再来看一下MySQL,你会发现从MySQL 5.7 引入了两个重量级的特性,正好符合Uber的需求:

  • DocumentStore

    ERMEB域名PHP离线网络授权系统
    ERMEB域名PHP离线网络授权系统

    感谢您选择使用ERMEB域名授权离线网络验证系统(简称:ERMEB域名授权系统)是ERMEB团队开发,ERMEB域名授权系统是国内最稳定,最强大,最先进的域名授权管理平台解决方案之一,ERMEB域名授权系统采用PHP +Mysql的技术,ERMEB域名授权系统框架使用Thinkphp6/mysql数据库基于Markdown开发者文档开发而成,项目安装请参考ThinkPHP官方文档及下面的服务环境说

    下载
  • X-协议

下面分别说明一下:

DocumentStore

从MySQL 5.7后可以认为MySQL也开始NoSQL了,支持json类型,加入更多的json支持 。感受一下:

934.jpg

支持CRUD等传统SQL操作。为了更好的支持NoSQL接口,在此基础又推出了另一个重量级的协议:X-协议。以及围绕着推出一堆的 mysqlsh ,各种程序的 Driver。如果你现在还不去了解,可能很快就Out喽

X-协议
全新的协议, 减少交互开销, 减少消息大小,支持管道处理,支持通知处理

对NoSQL支持更友好,更丰富的数据处理接口,考虑到数据Sharding实现
 更高速的Query响应

上面这两个功能也是MySQL 8.0要重点发力的两个功能。知识更新很快,如果还不知这两个的特性的朋友,要抓紧时间更新一下知识了。MySQL开始要发威了,最近更新非常的快。

也正是这两个特性,正好满足Uber的需求,基于NoSQL接口存储,底层数据保障使用MySQL的Replication复制(MySQL Group Replication马上也GA了)。在NoSQL接口层很容易做到数据的拆分及路由设制,底层复制又较好的保证的数据可用安全性。

MySQL已经不是当初的那个关系型数据库了,现在有更多特性需要你去深入挖掘

以上就是关于Uber选择MySQL的思考的内容,更多相关内容请关注PHP中文网(www.php.cn)!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

8

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

3

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

1

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

1

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

1

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

61

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

52

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

25

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

31

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 820人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号