部署MySQL Galera Cluster
部署MySQL Galera Cluster
0.功能简介
特性
- 基于行复制的完全并行同步复制
- 实时多主架构,任意节点可读写
- 无延迟复制,事务零丢失,可靠健壮的读写体验。
- 自动化节点关系控制:节点故障自动摘除,节点加入自动协调
- 接近原生的MySQL数据库连接的体验
原理简析
当一个事务在当前写入的节点提交后,通过wsrep API
(write set replication API)将这个事务变成写集(write set)广播到同集群的其他节点中,其他节点收到写集事务后,对这个事务进行可行性检查,并返回结果给wsrep API。
若大多数节点都预估自己可以成功执行这个事务,则wsrep API
会做出仲裁,通知所有可以成功执行这个事务的节点提交这个事务,并将事务成功提交的消息返回给客户端,同时根据需要剔除没有成功执行事务的节点
galera
共享库
galera
本身是作为一个插件式的共享库文件,MySQL通过调用galera
写集复制API挂钩,获得galera集群特性。
galera共享库组成部分
galera库是一个提供准备,复制,应用写集事务功能的协议栈,其重要组成部分为:
- wsrep API:写集复制功能组件,负责提供关系型数据库管理与复制服务,定义接口
- wsrep hooks:在数据库引擎中的集成写集组件
- Gelera Provider:将共享库转化为wsrep API
- Certification Layer:保护写集并完整性,验证写集完整性
- replication:管理复制协议,提供完整的指令系统
- GCS framwork:为集群组通信提供插件架构
1.环境准备
MySQL版本:5.6.41
服务器:
1192.168.33.14 node4
2192.168.33.15 node5
3192.168.33.16 node6
修改hosts文件
1vim /etc/hosts
2192.168.33.14 node4
3192.168.33.15 node5
4192.168.33.16 node6
2.安装带wsrep
的mysql
版本
1# 分别在3台服务器上安装mysql
2# 安装基本工具
3yum -y install lsof rsync wget
4
5# 解压
6wget http://releases.galeracluster.com/mysql-wsrep-5.6/binary/mysql-wsrep-5.6.41-25.23-linux-x86_64.tar.gz
7tar xf mysql-wsrep-5.6.41-25.23-linux-x86_64.tar.gz
8mv mysql-wsrep-5.6.41-25.23-linux-x86_64 /usr/local/mysql
9
10# 创建用户及用户组
11groupadd -g 306 mysql
12useradd -u 306 -g 306 mysql
13chown -R mysql:mysql /usr/local/mysql
14
15# 安装依赖
16yum -y install perl-Module-Install
17cd /usr/local/mysql
18./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/home/mysql/mysqldata
19
20# 配置开机启动
21cp support-files/mysql.server /etc/init.d/mysqld
22chmod +x /etc/init.d/mysqld
23if grep '^basedir=$' /etc/init.d/mysqld > /dev/null; then
24 sed -i 's#^basedir=$#basedir=/usr/local/mysql#' /etc/init.d/mysqld
25fi
26if grep '^datadir=$' /etc/init.d/mysqld > /dev/null; then
27 sed -i 's#^datadir=$#datadir=/home/mysql/mysqldata#' /etc/init.d/mysqld
28fi
29chkconfig --add mysqld
30chkconfig mysqld on
31service mysqld start
32
33# 添加环境变量
34cat > /etc/profile.d/mysql.sh <<EOF
35export PATH=/usr/local/mysql/bin:$PATH
36EOF
37source /etc/profile
38
39# 初始化配置
40mysql_secure_installation <<EOF
41
42y
43oeasy808
44oeasy808
45y
46n
47y
48y
49EOF
50
51# 配置完成之后,停止mysql服务
52service mysqld stop
3.安装galera
1# 分别在3台服务器上安装galera
2wget http://releases.galeracluster.com/galera-3/centos/7/x86_64/galera-3-25.3.24-2.el7.x86_64.rpm
3yum -y install galera-3-25.3.24-2.el7.x86_64.rpm
4.配置集群
1ip_addr=$(ip addr show $(ip route |grep default |awk '{print $5}')| grep inet |grep -Po '(\d+\.){3}\d+' | awk '{print $1;exit}')
2mysql_id=$(echo $ip_addr | awk -F. '{print $NF}')
3cat > /etc/my.cnf <<EOF
4[mysqld]
5skip-name-resolve=1
6binlog_format=ROW
7default-storage-engine=innodb
8innodb_autoinc_lock_mode=2
9innodb_locks_unsafe_for_binlog=1
10query_cache_size=0
11query_cache_type=0
12bind_address=${ip_addr}
13server-id=${mysql_id}
14
15wsrep_on=ON
16wsrep_provider=/usr/lib64/galera-3/libgalera_smm.so
17wsrep_cluster_name="galera_cluster"
18wsrep_cluster_address="gcomm://192.168.33.14,192.168.33.15,192.168.33.16" #全部集群节点
19wsrep_node_name=cluster1 #节点名称-唯一
20wsrep_slave_threads=1
21wsrep_certify_nonPK=1
22wsrep_max_ws_rows=131072
23wsrep_max_ws_size=1073741824
24wsrep_debug=0
25wsrep_convert_LOCK_to_trx=0
26wsrep_retry_autocommit=1
27wsrep_auto_increment_control=1
28wsrep_drupal_282555_workaround=0
29wsrep_causal_reads=0
30#wsrep_notify_cmd=
31wsrep_sst_method=rsync
32wsrep_sst_auth=root:oeasy808 #安装mysql时配置的密码
33EOF
5.启动集群
第一次在第1台服务器上启动
1/etc/init.d/mysqld bootstrap
在其他服务器上启动
1service mysqld start
6.验证集群
1# 查看集群节点状态
2mysql -p
3> show status like 'wsrep%';
4wsrep_incoming_addresses | 192.168.33.16:3306,192.168.33.15:3306,192.168.33.14:3306
5# 看到这个说明3个节点已经加到集群中了
测试读写性能
分别在不同的服务器上进行读写操作,然后在其他服务器上观察效果
- 原文作者:黄忠德
- 原文链接:https://huangzhongde.cn/post/mysql-galera-cluster/
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。