博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Uber系统从Postgres迁移到MySQL
阅读量:6256 次
发布时间:2019-06-22

本文共 957 字,大约阅读时间需要 3 分钟。

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

\\

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

\\

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

\\

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

\\

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

\\

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

\\

查看英文原文:

\\

感谢对本文的审校。

\

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

转载地址:http://qlxsa.baihongyu.com/

你可能感兴趣的文章
Spring技术内幕3——Spring AOP原理(二)
查看>>
学用 ASP.Net 之 System.Collections.Specialized.StringCollection 类
查看>>
CloudStack 实现VM高可用特性
查看>>
数据加密的相关知识
查看>>
扯淡的多播参数IP_MULTICAST_LOOP
查看>>
利用华为三层交换机实现vlan间互访
查看>>
【网络管理员必读】拒绝服务***防范措施 网络分析
查看>>
我的友情链接
查看>>
Struts2 的HelloWorld问题与解决
查看>>
Office 365 On MacOS 系列——安装 Office 2016 for Mac
查看>>
19个心得 明明白白说Linux下的负载均衡
查看>>
Collectl:Linux系统监控神器
查看>>
用 Nginx 来做私有 docker registry 的安全控制
查看>>
PHP程序员要知道的几个有用的PHP函数
查看>>
GAUGE、COUNTER和DERIVE类型
查看>>
libvirt kvm 虚拟机上网 – Bridge桥接
查看>>
OpenStack简介
查看>>
我的友情链接
查看>>
Linux_ 文本处理三剑客中的“大宝剑“—Grep家族
查看>>
监控摄像机供电方式的设计
查看>>