MariaDB Galera Cluster 部署

MariaDB作为Mysql的一个分支,在开源项目中已经广泛使用,例如大热的openstack,所以,为了保证服务的高可用性,同时提高系统的负载能力,集群部署是必不可少的。

MariaDB Galera Cluster 介绍

MariaDB Galera Cluster 是开源的 MariaDB同步多主机集群。它仅支持XtraDB/ InnoDB存储引擎(虽然有对MyISAM实验支持 - 看wsrep_replicate_myisam系统变量)。

主要功能:

  • 同步复制
  • 真正的multi-master,即所有节点可以同时读写数据库
  • 自动的节点成员控制,失效节点自动被清除
  • 新节点加入数据自动复制
  • 真正的并行复制,行级
  • 用户可以直接连接集群,使用感受上与MySQL完全一致

优势:

  • 因为是多主,所以不存在Slavelag(延迟)
  • 不存在丢失事务的情况
  • 同时具有读和写的扩展能力
  • 更小的客户端延迟
  • 节点间数据是同步的,而Master/Slave模式是异步的,不同slave上的binlog可能是不同的

技术:

Galera集群的复制功能基于Galeralibrary实现,为了让MySQL与Galera library通讯,特别针对MySQL开发了wsrep API。

Galera插件保证集群同步数据,保持数据的一致性,靠的就是可认证的复制,工作原理如下图: 

当客户端发出一个commit的指令,在事务被提交之前,所有对数据库的更改都会被 write-set 收集起来,并且将write-set 纪录的内容发送给其他节点。

write-set 将在每个节点进行认证测试,测试结果决定着节点是否应用write-set更改数据。

如果认证测试失败,节点将丢弃 write-set ;如果认证测试成功,则事务提交。

1 安装环境准备

安装MariaDB集群至少需要3台服务器(如果只有两台的话需要特殊配置,请参照官方文档

在这里,我列出试验机器的配置:

操作系统版本:centos7

  • node4:10.128.20.16
  • node5:10.128.20.17
  • node6:10.128.20.18

以第一行为例,node4为 hostname ,10.128.20.16为 ip ,在三台机器修改 /etc/hosts 文件,我的文件如下:


  1. 10.128.20.16 node4
  2. 10.128.20.17 node5
  3. 10.128.20.18 node6

为了保证节点间相互通信,需要禁用防火墙设置(如果需要防火墙,则参照官方网站增加防火墙信息设置)

在三个节点分别执行命令:


  1. systemctl stop firewalld

然后将 /etc/sysconfig/selinux 的 selinux 设置成 disabled ,这样初始化环境就完成了。

2 安装 MariaDB Galera Cluster


  1. [root@node4 ~]# yum install -y mariadb mariadb-galera-server mariadb-galera-common galera rsync

  1. [root@node5 ~]# yum install -y mariadb mariadb-galera-server mariadb-galera-common galera rsync

  1. [root@node6 ~]# yum install -y mariadb mariadb-galera-server mariadb-galera-common galera rsync

3 配置 MariaDB Galera Cluster

初始化数据库服务,只在一个节点进行


  1. [root@node4 mariadb]# systemctl start mariadb
  2. [root@node4 mariadb]# mysql_secure_installation
  3. NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB
  4. SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
  5. In order to log into MariaDB to secure it, we'll need the current
  6. password for the root user. If you've just installed MariaDB, and
  7. you haven't set the root password yet, the password will be blank,
  8. so you should just press enter here.
  9. Enter current password for root (enter for none):
  10. OK, successfully used password, moving on...
  11. Setting the root password ensures that nobody can log into the MariaDB
  12. root user without the proper authorisation.
  13. Set root password? [Y/n]
  14. New password:
  15. Re-enter new password:
  16. Password updated successfully!
  17. Reloading privilege tables..
  18. ... Success!
  19. By default, a MariaDB installation has an anonymous user, allowing anyone
  20. to log into MariaDB without having to have a user account created for
  21. them. This is intended only for testing, and to make the installation
  22. go a bit smoother. You should remove them before moving into a
  23. production environment.
  24. Remove anonymous users? [Y/n] n
  25. ... skipping.
  26. Normally, root should only be allowed to connect from 'localhost'. This
  27. ensures that someone cannot guess at the root password from the network.
  28. Disallow root login remotely? [Y/n] y
  29. ... Success!
  30. By default, MariaDB comes with a database named 'test' that anyone can
  31. access. This is also intended only for testing, and should be removed
  32. before moving into a production environment.
  33. Remove test database and access to it? [Y/n] n
  34. ... skipping.
  35. Reloading the privilege tables will ensure that all changes made so far
  36. will take effect immediately.
  37. Reload privilege tables now? [Y/n] y
  38. ... Success!
  39. Cleaning up...
  40. All done! If you've completed all of the above steps, your MariaDB
  41. installation should now be secure.
  42. Thanks for using MariaDB!

关闭数据库,修改 /etc/my.cnf.d/galera.cnf


  1. [root@node4 mariadb]# systemctl stop mariadb

  1. [root@node4 ~]# vim /etc/my.cnf.d/galera.cnf

修改以下内容:


  1. [mysqld]
  2. ......
  3. wsrep_provider = /usr/lib64/galera/libgalera_smm.so
  4. wsrep_cluster_address = "gcomm://node4,node5,node6"
  5. wsrep_node_name = node4
  6. wsrep_node_address=10.128.20.16
  7. #wsrep_provider_options="socket.ssl_key=/etc/pki/galera/galera.key; socket.ssl_cert=/etc/pki/galera/galera.crt;"

提示:如果不用ssl的方式认证的话,请把 wsrep_provider_options 注释掉。

将此文件复制到node5、node6,注意要把 wsrep_node_name 和 wsrep_node_address 改成相应节点的hostname 和 ip

4 启动 MariaDB Galera Cluster 服务


  1. [root@node4 ~]# /usr/libexec/mysqld --wsrep-new-cluster --user=root &

观察日志:


  1. [root@node4 ~]# tail -f /var/log/mariadb/mariadb.log
  2. 150701 19:54:17 [Note] WSREP: wsrep_load(): loading provider library 'none'
  3. 150701 19:54:17 [Note] /usr/libexec/mysqld: ready for connections.
  4. Version: '5.5.40-MariaDB-wsrep' socket: '/var/lib/mysql/mysql.sock' port: 3306 MariaDB Server, wsrep_25.11.r4026

出现 ready for connections ,证明我们启动成功,继续启动其他节点:


  1. [root@node5 ~]# systemctl start mariadb

  1. [root@node6 ~]# systemctl start mariadb

可以查看 /var/log/mariadb/mariadb.log,在日志可以看到节点均加入了集群中。

警告:--wsrep-new-cluster 这个参数只能在初始化集群使用,且只能在一个节点使用。

5 查看集群状态

我们可以关注几个关键的参数:

wsrep_connected = on 链接已开启

wsrep_local_index = 1 在集群中的索引值

wsrep_cluster_size =3 集群中节点的数量

wsrep_incoming_addresses = 10.128.20.17:3306,10.128.20.16:3306,10.128.20.18:3306 集群中节点的访问地址

6 验证数据同步

我们在 node4 上新建数据库 galera_test ,然后在 node5 和 node6 上查询,如果可以查询到 galera_test 这个库,说明数据同步成功,集群运行正常。


  1. [root@node4 ~]# mysql -uroot -proot -e "create database galera_test"

  1. [root@node5 ~]# mysql -uroot -proot -e "show databases"
  2. +--------------------+
  3. | Database |
  4. +--------------------+
  5. | information_schema |
  6. | galera_test |
  7. | mysql |
  8. | performance_schema |
  9. +--------------------+

  1. [root@node6 ~]# mysql -uroot -proot -e "show databases"
  2. +--------------------+
  3. | Database |
  4. +--------------------+
  5. | information_schema |
  6. | galera_test |
  7. | mysql |
  8. | performance_schema |
  9. +--------------------+

至此,我们的 MariaDB Galera Cluster 已经成功部署。


原文发布时间为:2015-07-09


本文来自合作伙伴“Linux中国”

时间: 2024-09-23 07:28:06

MariaDB Galera Cluster 部署的相关文章

nginx as Database Load Balancer for MySQL or MariaDB Galera Cluster

原文链接 Nginx is well-known for its ability to act as a reverse-proxy with small memory footprint. It usually sits in the front-end web tier to redirect connections to available backend services, provided these passed some health checks. Using a reverse

Galera Cluster:一种新型的高一致性MySQL集群架构

1. 何谓Galera Cluster 何谓Galera Cluster?就是集成了Galera插件的MySQL集群,是一种新型的,数据不共享的,高度冗余的高可用方案,目前Galera Cluster有两个版本,分别是Percona Xtradb Cluster及MariaDB Cluster,都是基于Galera的,所以这里都统称为Galera Cluster了,因为Galera本身是具有多主特性的,所以Galera Cluster也就是multi-master的集群架构,如图1所示: 图1

CentOS 6.7上编译+YUM两种方法配置MariaDB Galera多主集群实现HA

个人感觉MariaDB Galera做跨机房多主还是很方便的,比直接用MySQL做主从好.跟其他集群一样,为了避免节点出现脑裂而破坏数据,建议Galera集群最低添加3个节点.Galera 集群在高并发的情况下,多主同时写入时可能会发生事务冲突,此时只有一个事务请求会成功,其他的全部失败.可以在写入/更新失败时,自动重试一次,再返回结果.节点中每个节点的地位是平等的,没有主次,向任何一个节点读写效果都是一样的.实际可以配合VIP/LVS或HA使用,实现高可用性.如果集群中的机器全部重启,如机房断

CentOS7+MySQL/MariaDB+Galera+HAProxy+Keepalived构建高可用数据库集群

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://dgd2010.blog.51cto.com/1539422/1603972 方案优势: Galera能够实现MySQL/MariaDB数据库的主主复制和多主复制等模式,这些复制模式都是同步进行的,同步时间非常短 每一个节点都可以同时写入和读取,当某一节点发生故障时,可自动从集群中自动剔除 HAProxy能提供负载均衡和故障判断等功能解决服务器系统存在的单点故障 Keepaliv

转 mariadb集群介绍

The most recent release of MariaDB Galera Cluster 5.5 is: MariaDB Galera Cluster 5.5.34 官方网址: https://mariadb.com/kb/en/galera/ 原文地址:http://blog.sina.com.cn/s/blog_704836f40101lixp.html Galera Cluster介绍 Galera是一个MySQL(也支持MariaDB,Percona)的同步多主集群软件,目前只

数据库mysql,oracle,sqlite,mariadb 相关收藏

数据库 mysql MySql动态SQL - 风生水起 - 博客园 MySQL :: MySQL 5.1参考手册 :: B. 错误代码和消息 mysql 表空间及索引的查看 - 爱测试的猫咪 - 博客园 复制 mysql数据库复制_百度文库 mysql数据库'复制'的办法 - wren_blog - 51CTO技术博客 命令 Out of resources when opening file './xxx.MYD' (Errcode: 24) 解决 - MySQL - Database - C

MariaDB: 选择性二进制日志事件 【已翻译100%】

作为MariaDB一系列有趣特性的第一篇文章,我们从选择性跳过复制binlog事件开始.MariaDB 5.5和10支持此特性. 默认情况下使用MySQL标准复制功能时,所有事件都记录在二进制日志中,并复制到所有从机(可以过滤掉一些模式).但使用此特性,可以在从机上跳过一些事件的复制,即使这些事件是被写入到二进制日志中的.在二进制日志中保存那些事件对于时间点恢复来说总是有用的. 的确,当不需要复制一个事件时,我们通常会设置 sql_log_bin = 0 ,该事件就会被跳过:既不会写入binlo

从MySQL迁移到MariaDB(CentOS)

下面先摘录一点背景介绍,然后是我在 CentOS 6.4 上从 MySQL 5.5.31 迁移至 MariaDB 5.5.31 的操作记录.最后是我后来发现一个较好的迁移方法. 1. 背景介绍 MySQL是世界上最流行的开源关系数据库.2008 年,Sun 收购 MySQL.然后 2010 年,甲骨文又收购了 Sun,于是 MySQL 落入了甲骨文(Oracle)手中.Oracle 与开源社区关系的一直不太好,甚至 MySQL 也被弄成了社区版和企业版,不能免费商业使用:MySQL 企业版的新功

MySQL高可用在网易的最佳应用与实践

今天分享主要包括三方面内容:一是常见的MySQL高可用架构;二是分布式数据库高可用实践;三是基于keepalive的MySQL高可用改造.第一部分会介绍业界一些经典的MySQL高可用解决方案,第二部分和第三部分分别介绍网易在分布式数据库和单节点MySQL上的高可用运维实践. 一.常见的MySQL高可用架构 MySQL高可用主要涉及两个方面,一是客户端如何切换,如何自动failover,二是多个MySQL节点之间如何做数据同步.业界MySQL高可用的解决方案有很多,总结起来有几类:从客户端自动切换