不管是采用binlog或者GTID的方式,其本质都是经过I/O_thread和sql_thread的形式进行的同步,由于没法避免复制延迟而饱受诟病,基于上述MariaDB引入了Galera Cluster来解决此问题。mysql
Galera Cluster与传统的复制方式不一样,不经过I/O_thread和sql_thread进行同步,而是在更底层经过wsrep实现文件系统级别的同步,能够作到几乎实时同步,而其上的MySQL对此一无所知sql
这就要求MySQL可以调用wsrep提供的API来完成,在Mariadb10.1以前的版本,支持Galera Cluster的版本是与Mariadb分开发行的,其版本名称就成为Mariadb-Galera,Mariadb10.1之后的版本中MariaDB Galera Cluste再也不单独发行,而是以galera-25.3.12-2.el7.x86_64包的形式出现方面都强过MySQL。数据库
MariaDB Galera Cluster主要功能服务器
同步复制:真正的multi-master,即全部节点能够同时读写数据库自动的节点成员控制,失效节点自动被清除新节点加入数据自动复制真正的并行复制,行级用户能够直接链接集群,使用感觉上与MySQL彻底一致网络
MariaDB Galera Cluster的优缺点并发
1.优点:异步
2.缺点:分布式
还有一些地方存在局限:ide
毕竟基于MySQL创始人领衔开发的MariaDB数据库,确定是知道MYSQL数据库存在的弱项,而后提供更好的兼容性和扩展性,咱们基本上彻底能够将MYSQL数据库建议到MariaDB数据库中,并且MariaDB发展速度和升级速度远远优先。函数
因为MySQL在被收购以后更新速度与性能的优化很是的缓慢,并且是闭源的,彻底没有Oracle以外的人参与进来,不少须要解决的问题都没有升级进去,反之不少公司虽然也有利用本身开发的分支Mysql版本。
MariaDB基于事务的Maria存储引擎,替换了MySQL的MyISAM存储引擎,它使用了Percona的 XtraDB,InnoDB的变体,MariaDB默认的存储引擎是Aria,不是MyISAM。Aria能够支持事务,可是默认状况下没有打开事务支持,由于事务支持对性能会有影响。MariaDB是一个采用Maria存储引擎的MySQL分支版本,是由原来 MySQL 的做者Michael Widenius创办的公司所开发的免费开源的数据库服务器。
这个直观的区别在于MariaDB可以快速的查询和处理数据,且占用资源相对是少于MySQL数据库的,并且在运行速度、以及支持对 Unicode 的排序问题优于MYSQL数据库。