写点什么

Uber 系统从 Postgres 迁移到 MySQL

  • 2016-08-25
  • 本文字数:986 字

    阅读完需:约 3 分钟

Uber 最近在博客中详细阐述了他们为什么要使用MySQL 来替代PostgreSQL 。Uber 遇到的主要困难源于Postgres 的写入放大问题。写入放大是在对涉及索引的单行数据进行更新时,需要更新所有的索引,从而导致大量对磁盘的写操作,在使用固态硬盘时这个问题更加严重。 HOT(Heap-Only-Tuples) 特性可以缓解这个问题,这在一些用例中也许是一个解决方案。因此,写入放大问题泄漏到了复制过程中,造成为了一些简单的更新而在副本间传播多个更新操作。在灾难恢复的场景中,由于数据中心之间可能相距较远,并且无法获得廉价、便利的带宽,就会导致重大问题。

在 Postgres 9.2 的一次常规更新中,一个 bug 导致了一些表的数据损坏。这是由于没有标记一些应该被标记为不活跃的数据所导致的。无法计算这个 bug 这所影响到的数据总数,而且由于复制是发生在物理层,这也就存在着损坏数据库索引的风险。

Postgres 的副本并没有真正支持多版本并发控制(MVCC)。副本必须和主节点使用一致的预写式日志(WAL: Write Ahead Log )。加上如果更新操作涉及其他事务中已打开的行,Postgres 会将其阻塞,这在很大程度上会影响长事务(long running transaction)。一旦长事务阻塞了预写式日志线程,就会被 Postgres 终止,如果应用开发人员没有意识到这点,特别是在使用事务边界不透明的对象关系映射(ORM)时,就会带来问题。

再一次由于复制过程是工作在物理层,数据库更新不得不在所有副本间同时进行,不然复制无法正常工作。这意味着就 Uber 的规模来说,升级到当时的新版本真的会造成很多问题。这个问题已经自 9.4 版本之后使用 pglogical 修复了。

在决定 Uber 案例的设计方案时,设计者看重 MySQL 的优势有:拥有灵活的副本、每个连接使用轻量级的线程而不是进程、廉价的缓存。应对磁盘存储上的主要问题,则使用 InnoDB 存储,使压缩更高效而不会影响大量索引或引起 Postgres 中的写入放大问题。

Markus Winand Simon Riggs Robert Haas 针对 Uber 用例提出了一些很好的反驳。他们详细阐述了在诸多用例中如何解决上述问题,以及为什么并不是对每个案例都应该抛弃 Postgres 而使用 MySQL,反之亦然。

查看英文原文: Uber Engineering Moving from Postgres to MySQL


感谢百占辉对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-08-25 19:004124
用户头像

发布了 41 篇内容, 共 13.6 次阅读, 收获喜欢 3 次。

关注

评论

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

Python动态变量名定义与调用方法

百度搜索:蓝易云

Python 云计算 Linux 运维 云服务器

mybatisplus多租户原理略解

百度搜索:蓝易云

云计算 Linux 运维 mybatis 云服务器

支付系统概述(十):风控能力

agnostic

支付系统设计与实现

OneCommander Pro(双窗口文件管理工具)v3.76.0.0 特别版+便携版win版

iMac小白

One Commander 3下载 One Commander 3 mac One Commander 3特别版

route命令小结

百度搜索:蓝易云

Linux 运维 IP Route

MATLAB R2024a(商业数学软件)mac/win

iMac小白

MATLAB下载 MATLAB2024 MATLAB2024破解版下载

Sound Siphon for Mac:强大的音频传输与录制神器

iMac小白

基于AB32VG1的冬笋探测器设计

芯动大师

lcd 微波

Perfectly Clear Workbench(图片编辑软件)mac/win

iMac小白

Radiant Photo(照片编辑美化软件)特别版win

iMac小白

“愤怒的女友”:AI模拟女友生气、让男士们练习交流技巧

算AI

人工智能 AI 创新

关于Ingress-nginx的跨域配置

百度搜索:蓝易云

nginx Linux 运维 https HTTP

git快速查看某个文件修改的所有commit

百度搜索:蓝易云

git 云计算 运维 log 云服务器

OceanBase 开发者大会资料

菜根老谭

oceanbase

2024-04-21:用go语言,给一棵根为1的树,每次询问子树颜色种类数。 假设节点总数为n,颜色总数为m, 每个节点的颜色,依次给出,整棵树以1节点做头, 有k次查询,询问某个节点为头的子树,一共

福大大架构师每日一题

福大大架构师每日一题

提升用户体验的UUID设计策略

南城FE

JavaScript 前端 后端 nodejs uuid

Nevercenter CameraBag Pro for Macv2024.1激活版:专业的照片滤镜与编辑工具

iMac小白

Navicat Premium 16 for Mac(数据库管理软件)v16.3.7中文激活版

iMac小白

安装plsql developer 64位

麦兜

Photomator for Mac v3.3.5中文版:强大的照片编辑工具

iMac小白

Iris for Mac:全方位屏幕护眼与录制利器

iMac小白

Uber系统从Postgres迁移到MySQL_数据库_Alex Giamas_InfoQ精选文章