MariaDB Galera Cluster 部署

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

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中国”

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
SQL 关系型数据库 MySQL
Docker 部署离线版 Nginx 镜像容器,Tomcat 镜像容器,Mariadb 镜像容器
Docker 部署离线版 Nginx 镜像容器,Tomcat 镜像容器,Mariadb 镜像容器
2136 0
Docker 部署离线版 Nginx 镜像容器,Tomcat 镜像容器,Mariadb 镜像容器
|
Cloud Native 关系型数据库 数据库
云原生之使用Docker部署Mariadb数据库
云原生之使用Docker部署Mariadb数据库
622 0
云原生之使用Docker部署Mariadb数据库
|
运维 负载均衡 关系型数据库
【运维知识进阶篇】用Ansible Roles重构LNMP架构(Linux+Nginx+Mariadb+PHP),实现4个项目一键部署
【运维知识进阶篇】用Ansible Roles重构LNMP架构(Linux+Nginx+Mariadb+PHP),实现4个项目一键部署
180 0
|
关系型数据库 MySQL Linux
如何在CentOS 7服务器上配置使用MariaDB的Galera集群:
如何在CentOS 7服务器上配置使用MariaDB的Galera集群:
|
弹性计算 安全 关系型数据库
阿里云部署javaWeb项目依赖软件(jdk、tomcat、Mariadb数据库)的安装
阿里云部署javaWeb项目(jdk、tomcat、Mariadb数据库)的安装 🍅 程序员小王的博客:程序员小王的博客 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 如有编辑错误联系作者,如果有比较好的文章欢迎分享给我,我会取其精华去其糟粕 🍅java自学的学习路线:java自学的学习路线
369 0
阿里云部署javaWeb项目依赖软件(jdk、tomcat、Mariadb数据库)的安装
|
弹性计算 安全 关系型数据库
阿里云部署javaWeb项目依赖软件(jdk、tomcat、Mariadb数据库)的安装
阿里云部署javaWeb项目(jdk、tomcat、Mariadb数据库)的安装
阿里云部署javaWeb项目依赖软件(jdk、tomcat、Mariadb数据库)的安装
|
关系型数据库 网络安全 数据库
|
关系型数据库
下载安装MariaDB Galera 10.1
因为无法访问外网, 配置官网的yum无法下载MariaDB Galera(在MariaDB 10.1 及之后内置了Galera, 不像之前那样需要独立安装) 需要在下载的包 MariaDB-10.1.31-centos73-x86_64-client.
1495 0