前期回顾

主机名 IP地址 操作系统 MySQL版本 插件版本
rac1 11.12.14.29 Redhat 6.10 5.7.26 25.3.27
rac2 11.12.14.30 Redhat 6.10 5.7.26 25.3.27
rac3 11.12.14.39 Redhat 6.10 5.7.26 25.3.27

前面我们说了Galera Cluster有三种不同的分支

  • MySQL Galera Cluster by Codership
  • Percona XtraDB Cluster by Percona
  • MariaDB Galera Cluster (5.5 and 10.0) by MariaDB

上面我们说了如何一步步搭建MySQL Galera集群

这节内容主要讲其和单机的MySQL有何不同点,包含一些需求和限制

1. 服务器不同

Galera需要和传统的单机不一样,其需要集成一些补丁,并且在二进制日志和字符集的处理上也不一样

2. 操作系统支持

Galera 支持Linux和类UNIX操作系统,二进制包不在FreeBSD, Solaris and Mac OS X上提供

同时不支持Windows操作系统

3. 二进制日志支持

不要使用binlog-do-db and binlog-ignore-db选项

这些二进制日志选项只支持DML语句,不知道DDL语句,可能会造成复制中断

4. 不支持的字符集

不要使用UTF-16, UTF-32 or UCS-2字符集

当使用rsync 方法进行SST时,使用这些字符集可能会导致服务崩溃

5. 表配置的不同

一些传统数据库的表配置可能Galera不同,如存储引擎支持,查询缓存等

6. 存储引擎支持

Galera只支持innodb存储引擎,其他的非事务型存储引擎如MyISAM将无法被复制,只会同步DDL不会同步DML,如新建一张MyISAM表并插入数据,其他节点会新建表但是不会插入数据(行数为0)

7.无主键表

不要使用无主键的表,需要为表设置主键,如果实在没有,可以设置自动增长(AUTO_INCREMENT )的列

8. 表锁

Galera不支持表锁,因为会和多主冲突,所以LOCKTABLES and UNLOCK TABLES 语句不被支持,同样GET_LOCK() and RELEASE_LOCK()函数也不可以使用

9.查询日志

Galera无法将查询日志定向到表中,如有需求,你必须将其定向到文件中

log_output = FILE

10.事务的不同

  • Galera不支持分布式事务XA
  • 事务的大小上也有限制,否则会大幅降低Galara性能,一般我们设置wsrep_max_ws_rows and the wsrep_max_ws_size参数来限制

11. 事务冲突解决

Galera中如果两个事务同时写同一行,而且是在不同的节点,此时只有一个事务会成功,另一个会被回滚,这时你需要重新执行失败的那一个

我们可以在日志中看到一段死锁警告

code (Error: 1213 SQLSTATE: 40001 (ER_LOCK_DEADLOCK)

5. 参考资料

https://galeracluster.com/library/training/tutorials/differences.html