负责galera上执行删除语句

delete from t1 where group_id= and group_id=;

执行后,群集破坏,除了主节点存活,其他俩个节点全都停掉。

查看galera的限制,没有主键的表,不支持DELETE操作。但是查看删除数据的表是有主键的,只不过删除不是根据主键删除,不知道是不是这个原因

galera官方的限制:

  • 当前的复制仅仅在 InnoDB 存储引擎 下才能工作。任何其他的引擎对数据表的写操作,都不会被复制( 包括系统表mysql.* )。但 CREATE USER 等实际上是修改了 mysql.* 的表的DDL语句是会被复制的。同时 galera 官方实验性的支持 MyISAM 引擎,具体请查看系统变量wsrep_replicate_myisam
  • 不支持如下的锁定:LOCK TABLES , FLUSH TABLES {table lists} WITH READ LOCK, GET_LOCK(),RELEASE_LOCK(),...。适当的使用事务可以克服这些限制。全局锁定操作是支持的,如FLUSH TALBES WITH READ LOCK
  • 所有的表都必须有一个主键(多列主键是支持的)。没有主键的表,不支持DELETE操作。同时,在没有主键的表中,内容行出现的顺序在集群的不同的节点中可能不同。
  • query log不能被记录到一张表中。如果你开启了查询日志,你需将日志导入到文件中:log_output=FILE
  • 不支持 XA transactions
  • 事物大小。galera没有明确限制事物大小。一个写入操作是在一个单独的内存缓存块中进行的,所以一个大的事务操作(如LOAD DATA)将会对节点的性能产生很大的不利影响。为了避免这个,系统变量 wsrep_max_ws_rowswsrep_max_ws_size 默认限制了事务的行数为12.8万,事务的大小为1G。如果有必要,可以增大这些配置。将来版本将支持事务碎片。

其他限制(排名不分先后):

  • 如果你使用mysqldump做状态迁移,如果过程中出现任何错误(如:您没有数据库账号,或者账号权限不对),都将在服务器的错误日志中出现SQL SYNTAX错误提示。不要被这个错误提示欺骗了,仅仅是一种奇葩的日志记录方式。伪语句中实际上包含了错误语句。
  • Do not use transactions of any essential size. 插入10万行,服务器将需要额外的200-300Mb。在一些不幸的场景中,50万行需要1.5Gb,100万行需要3.5Gb。
  • 当包含DDL时锁定是不严谨松散的。例如,如果你在DML操作时,并行的开始一个DDL语句,在通常的MySQL设置中,MySQL将等待元数据的锁定,但是在galera中却会不顾一切的执行。只要你配置的是集群模式,就算是只有一个节点,也会执行。这种行为可能引起一些副作用,导致的结果还没有进行深入研究。尽量避免这样的并行操作。
  • 不要依赖自增值。galera使用的机制是基于生成一个唯一的不冲突的序号来自增,所以每一次自增序号都有空白。见:http://codership.blogspot.com/2009/02/managing-auto-increments-with-multi.html
  • 一个命令可能失败ER_UNKNOWN_COM_ERROR产生"WSREP has not yet prepared node for application use"'Unknown command' in older versions 的错误信息。当集群进入脑裂并且节点是少数部分时。例如,当网络出现故障时,当节点暂时的和其他节点失去联系。同样也可能出现在状态变更的时候。节点采取这个措施来防止数据不一致。这通常是一个临时状态,可以通过检查wsrep_ready的值来监测。在这种状态下,运行执行showset命令。
  • 当发生短暂的断开后,集群健康的部分还是可以被访问的,如果他的状态被修改了,将开始重新同步。同时,集群中失败的部分将断开所有的客户端连接。这对客户端来说特别意外,尤其是在客户端是空闲的状态,并不知道到底发生了什么错误。需记住一点,在连接到这个孤立节点的连接恢复,如果有一个数据流在这个节点上,并且将要花很长时间才能同步,这时,健康的节点将会说集群准备好了而且是同步的,然后刚加入的节点会说她仅仅只是加入(还没同步)。这个连接会得到unknown command的回复。最终都会同步的。
  • 在启动前仔细检查binlog_format的配置是否为ROW,这个值可以在运行时改变。所以不要在运行时改变binlog_format的值。这不仅仅造成复制失败,而会让所有其他的节点崩溃。
  • 如果使用rsync来做状态迁移,当一个节点在状态迁移前崩溃时,rsync进程可能永远挂起了,占用着端口而且阻止节点重启。这个问题表现为在服务器的错误日志中出现"port in use"命令。找出这个孤儿rsync进程,然后手动杀掉。
  • 性能:从设计角度看,集群的性能不会比最慢的节点的性能高。同一台机器上,甚至是单节点的集群的性能也不是独立的数据库的性能好。特别是在大型的事务处理的时候。
  • 不支持Windows。
  • 复制过滤:在galera集群中,需要小心使用复制过滤。作为一个基本准则,除了InnoDB的DML更新操作,这些复制过滤是不被galera集群推崇的:binlog-do-db,binlog-ignore-db,replicate-wild-do-db,replicate-wild-ignore-db。然而replicate-do-db,replicate-ignore-db过滤是被InnoDB和MyISAM存储引擎的DDL和DML语句支持的。也就是说,必须小心使用复制过滤,因为可能造成数据差异和复制中断。
  • FLUSH PRIVILEGES不会被复制。
  • 5.5.40-galera和10.0.14-galera之前的版本,需要关闭query cache的功能。
  • 在设置异步复制时,在galera节点作为从节点时,在从节点上不支持并发复制(slave-parallel-threads>1)。

原文地址: https://mariadb.com/kb/en/mariadb/mariadb-galera-cluster-known-limitations/

参考

mariadb galera 集群注意事项(翻译) - 永福的博客 - OSCHINA https://my.oschina.net/foreverich/blog/743851

mariadb galera群集故障记录的更多相关文章

  1. Mariadb galera 群集

    环境:  CentOS 7 x64  *  3 IP : 192.168.0.100 IP : 192.168.0.101 IP : 192.168.0.102 配置mariadb YUM 源 htt ...

  2. Mariadb Galera Cluster 群集 安装部署

    #Mariadb Galera Cluster 群集 安装部署 openstack pike 部署  目录汇总 http://www.cnblogs.com/elvi/p/7613861.html # ...

  3. 从 MySQL+MMM 到 MariaDB+Galera Cluster : 一个高可用性系统改造

    很少有事情比推出高可用性(HA)系统之后便经常看到的系统崩溃更糟糕.对于我们这个Rails运行机的团队来说,这个失效的HA系统是MySQL多主复制管理器(MMM). 我们已经找寻MMM的替代品有一段时 ...

  4. Linux下MySQL/MariaDB Galera集群搭建过程

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  5. MariaDB Galera Cluster部署手册

    MariaDB Galera Cluster部署手册 galara保证双主数据库的同步及一致性 1.环境准备 基于新部署.最小化安装centos6.5 1>  yum install opens ...

  6. MariaDB Galera Cluster 10.1 只支持 LINUX ?!

    MariaDB Galera Cluster  (MariaDB 10.1) 当前只支持:LINUX ! 参考: https://mariadb.com/kb/en/mariadb/getting-s ...

  7. 【原】基于 HAproxy 1.6.3 Keeplived 在 Centos 7 中实现mysql mariadb galera cluster 集群分发读写 —— 上篇

    前言 有一段时间没有写blogs,乘着周末开始整理下haproxy + keeplived 实现 mysql mariadb galera cluster 集群访问环境的搭建工作. 本文集中讲hapr ...

  8. 迁移到MariaDB galera

    迁移到MariaDB galera [已注销] [已注销] -- :: [安装] ====== https://downloads.mariadb.org/mariadb/repositories/ ...

  9. MariaDB Galera Cluster 部署(如何快速部署 MariaDB 集群)

    MariaDB Galera Cluster 部署(如何快速部署 MariaDB 集群)  OneAPM蓝海讯通7月3日 发布 推荐 4 推荐 收藏 14 收藏,1.1k 浏览 MariaDB 作为 ...

随机推荐

  1. 微信小程序 时间戳 转化为 日期格式

    util.js  : function transTime(unixtime) { var dateTime = new Date(parseInt(unixtime) * 1000) var yea ...

  2. Linux 进程IO杂项

    Linux 进程IO杂项 本文结合一个 pwn 例题,在分析例题的过程中穿插介绍相关知识. 例题来源:PWNABLE.KR 网站,Toddler's Bottle 小节,习题 input. 例题内容: ...

  3. [dev][nginx] 在阅读nginx代码之前都需要准备什么

    前言 以前,我读过nginx的源码,甚至还改过.但是,现在回想起来几乎回想不起任何东西, 只记得到处都是回调和异步,我的vim+ctags索引起来十分吃力. 几乎没有任何收获,都是因为当时打开代码就看 ...

  4. 在openwrt上使用autossh(已放弃)

    用了一天后发现,这东西真不靠谱,还不如自已写的SHELL检测重连来的精准和方便,放弃中 参考文章: https://my.oschina.net/umu618/blog/849345 https:// ...

  5. 基于yum的方式安装Cloudera Manager Agent(使用Mysql 8.0版本)

    基于yum的方式安装Cloudera Manager Agent(使用Mysql 8.0版本) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.  一.选择CDH版本 1>.确认 ...

  6. XML DOM 知识点

    第一部分[DOM基础] DOM介绍: 1.什么是 HTML DOM? HTML DOM 定义了所有 HTML 元素的对象和属性,以及访问它们的方法(接口). 2.什么是 XML DOM? XML DO ...

  7. JAVA命名规范性总结

    一:命名规范 1.项目名全部小写2.包名全部小写 在新建一个包项目时可能会涉及到多层设计,每层的包名要遵循包名全部小写的规范,如图在一个功能的逐层上级的包名全部是小写的字符组成3.类名的命名要遵循首字 ...

  8. vmware联网解决方案:host-only共享上网

    一.需求说明 vmware通过桥接的方式可以上外网,但是虚拟机的IP地址必须和物理网卡在同一网段,上网环境不同虚拟机必须跟着换ip地址很麻烦,所以最好是采用host-only方式上网. 特别是做架构实 ...

  9. 关于Istio 1.1,你所不知道的细节

    本文整理自Istio社区成员Star在 Cloud Native Days China 2019 北京站的现场分享 第1则 主角 Istio Istio作为service mesh领域的明星项目,从2 ...

  10. 任何人都适合的常用Chrome插件(工欲善其事必先利其器)

    1.划词翻译 介绍链接:http://t.cn/RqpoGU4 下载地址: Chrome 应用商店(请翻墙). 下载 .crx 安装包手动安装 功能如下: - 支持几乎所有语言的翻译与阅读,并且同时支 ...