GaleraCluster大坑的解决方案

有些同学在使用Galera Cluster之后,会发现有一些坑,如:
1)大表DDL操作会导致整个集群不可用。在DDL操作完成前集群都不可写入任何事务,导致服务不可用。

成都创新互联是一家专注于网站设计制作、做网站与策划设计,安新网站建设哪家好?成都创新互联做网站,专注于网站建设十余年,网设计领域的专业建站公司;建站业务涵盖:安新等地区。安新做网站价格咨询:13518219792

解决方案:
直接使用pt-online-schema工具进行操作,可以避开这个问题。

2)由于Galera Cluster在执行DDL时,是Total Ordered Isolation(wsrep_OSU_method=TOI)的,所以必须要保证每个节点都是同时执行的,当然对于不是DDL的,也是Total Order的,因为每一个事务都具有同一个GTID值,DDL也不例外,而DDL涉及到的是表锁,MDL锁(Meta Data Lock),只要在执行过程中,遇到了MDL锁的冲突,所有情况下,都是DDL优先,将所有的使用到这个对象的事务,统统杀死,不管是读事务,还是写事务,被杀的事务都会报出死锁的异常,所以这也是一个Galera Cluster中,关于DDL的闻名遐迩的坑。

解决方案:
可以使用滚动升级方式在每个节点上分别执行DDL操作,这样就可以避开上面的问题。操作如下:

SET wsrep_OSU_method='RSU';

ALTER TABLE test ADD COLUMN user_age tinyint;

SET wsrep_OSU_method='TOI';

即先在节点上修改实例升级方式为滚动升级(Rolling Schema Upgrade),然后再执行DDL语句,最后再将实例升级方式修改回去。


本文名称:GaleraCluster大坑的解决方案
当前链接:http://bzwzjz.com/article/gpdopc.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站设计 成都网站建设公司 重庆网站制作 成都定制网站建设 攀枝花网站设计 温江网站设计 品牌网站建设 成都网站建设 成都网站建设 专业网站设计 网站建设开发 企业网站制作 营销型网站建设 成都商城网站制作 成都网站设计公司 专业网站设计 营销网站建设 成都网站设计 企业手机网站建设 成都网站建设 移动手机网站制作 盐亭网站设计