环境:centos7
vm1:10.154.47.236
vm2:10.154.52.189
vm3:10.105.12.50
目的:pxc使用三个节点构建mysql集群,使用innobackupex
对数据进行全局备份,增量备份;同时对三个节点做负载均衡(使用腾讯云官方负载均衡器)
补充:整个应用使用的都是内网,做负载均衡时会有vip(内网)提供给PHP应用。安全组只开放对外的80,443,22常用接口,内网端口互通.
安装PXC,innobackupex
安装软件依赖包(添加repl源,再安装依赖,3台server同样安装)
下载安装Percona-XtraDB-Cluster
yum install epel*
yum install perl-IO-Socket-SSL perl-DBD-MySQL perl-Time-HiRes socat nc -y
yum install -y libaio*
yum groupinstall -y 'Development tools'
yum install -y libssl.so.6
ln -sf /usr/lib64/libssl.so.10 /usr/lib64/libssl.so.6
ln -sf /usr/lib64/libcrypto.so.10 /usr/lib64/libcrypto.so.6
采用的是二进制安装,直接解压即可
下载在官网,https://www.percona.com/ --> software --> Percona XtraDB Cluster --> download --> liunx Generic --> 选择版本
#解压
tar zxvf Percona-XtraDB-Cluster-5.7.21-rel20-29.26.1.Linux.x86_64.ssl101.tar.gz
#
mv Percona-XtraDB-Cluster-5.7.21-rel20-29.26.1.Linux.x86_64.ssl101 /usr/local/mysql
创建mysql用户
useradd -M -s /sbin/nologin mysql
软连接命令
ln -s /usr/local/mysql/bin/* /usr/bin/
更改权限
chown -R mysql:mysql /data/mysql
chown -R mysql:mysql /usr/local/mysql
配置文件my.cnf
#需要添加的配置项
log_error=error.log
innodb_autoinc_lock_mode=2
wsrep_cluster_name=pxc-fss #节点名称保持一致
wsrep_provider=/usr/local/mysql/lib/libgalera_smm.so
wsrep_cluster_address=gcomm://10.105.12.50,10.154.52.189,10.154.47.236 #所有节点的ip,添加节点这里就需要添加
wsrep_node_address=10.154.47.236 #本机ip ,不同的server写各自ip
wsrep_slave_threads=8
wsrep_sst_auth=fss:u8u8uu8 #
wsrep_sst_method=xtrabackup-v2
wsrep_provider_options="gcache.size=8G;"
log-slave-updates
配置好后后面的启动会有很多错误,根据error.log
排查
我遇到的典型的就是binlog_format
的问题,需要设置为binlog_format = ROW
mysql复制主要有三种方式:基于SQL语句的复制(statement-based replication, SBR),基于行的复制(row-based replication, RBR),混合模式复制(mixed-based replication, MBR)。对应的,binlog的格式也有三种:STATEMENT,ROW,MIXED
可以详细了解哈 https://www.cnblogs.com/langtianya/p/5504774.html
初始化以及启动测试
mysqld --initialize --datadir=/data/mysql --user=mysql --basedir=/usr/local/mysql/
#初始化成功会在`/data/mysql`下产生数据文件
启动测试
在主节点10.154.47.236,其他节点启动方式不一样
mysqld_safe --defaults-file=/etc/my.cnf --ledir=/usr/local/mysql/bin --datadir=/data/mysql --wsrep-new-cluster &
#第一个节点启动需要加上--wsrep-new-cluster 参数,表示新建立集群
主节点启动后需要添加用户授权,从节点在使用SST时会使用账号(my.cnf中的账号wsrep_sst_auth=
)
不然会报错如下
2018-03-14T11:23:22.982182+08:00 0 [ERROR] WSREP: Process completed with error: wsrep_sst_xtrabackup-v2 --role 'joiner' --address 'IP地址省略' --datadir '/data/mysql/' --defaults-file '/etc/my.cnf' --defaults-group-suffix '' --parent '13752' '' : 2 (No such file or directory)
2018-03-14T11:23:22.982229+08:00 0 [ERROR] WSREP: Failed to read uuid:seqno from joiner script.
2018-03-14T11:23:22.982239+08:00 0 [ERROR] WSREP: SST script aborted with error 2 (No such file or directory)
2018-03-14T11:23:22.982275+08:00 0 [ERROR] WSREP: SST failed: 2 (No such file or directory)
2018-03-14T11:23:22.982277+08:00 0 [Warning] WSREP: 1.0 (VM_52_189_centos): State transfer to 0.0 (VM_47_236_centos) failed: -22 (Invalid argument)
2018-03-14T11:23:22.982286+08:00 0 [ERROR] Aborting
其他节点
mysqld_safe --defaults-file=/etc/my.cnf --ledir=/usr/local/mysql/bin --datadir=/data/mysql &
查看集群状态
MySQL [(none)]> SHOW STATUS LIKE '%wsrep%';
wsrep_cluster_conf_id | 4
wsrep_cluster_size | 2
wsrep_cluster_state_uuid | f6fcb98a-269b-11e8-a781-1af3e5d62be6
wsrep_cluster_status | Primary
wsrep_connected | ON
#wsrep_cluster_size 指出集群节点数
#wsrep_cluster_status 集群状态
到此PXC搭建完成!可以操作数据库测试下
里面很多细节没讲到,比如5.7版的数据库初始化后,密码竟然在error.log里面,/pass定位下就能看到,初始化时候数据目录不能有文件等等,细节问题及其多...
innobackupex备份恢复
之前在备份数据库都是用的mysqldump
,现在的测试,生产环境也是做的计划任务定时执行,备份的也是整库,innobackupex
则可以在全局备份后进行增量备份,这样就不用每次都将整个数据库打包压缩下来。整个原理也比较好理解,通过命令行也能大致了解到备份恢复逻辑
在是上面PXC集群搭建好后,我本来准备将用mysqldump
备份下来的数据解压,然后通过命令 mysql -root -p 库名 < /备份数据文件
导入进去,然而,发现并不行,好煞笔的感觉
进入重点,理论参考以下博客,很详细
https://www.cnblogs.com/kevingrace/p/6102683.html
备份恢复原理这篇文章很详细,可以仔细了解下
先全局备份正在运行的Mysql5.7
innobackupex --password=xxx /backup/
#backup为备份目录
#你会看到一个 ok ...
执行完命令后,/backup/目录下会生成一个时间戳目录,/backup/2018-03-13_16-33-41/
增量备份
innobackupex --password=xxx --incremental /backup/ --incremental-basedir=/backup/2018-03-13_16-33-41/
#--incremental-basedir 指向全局备份目录
# --incremental 指向备份目录
执行完命令后,/backup/目录下会生成一个新的时间戳目录,2018-03-13_16-35-46/
再次增量备份 新的时间戳,2018-03-13_16-37-59/
备份就是以上,还原如下。
停止数据库,并清空数据目录文件,包括之前的初始化数据
innobackupex --apply-log --redo-only /backup/2018-03-13_16-33-41/
innobackupex --apply-log --redo-only /backup/2018-03-13_16-33-41/ --incremental-dir=/backup/2018-03-13_16-35-46/
innobackupex --apply-log /backup/2018-03-13_16-33-41/ --incremental-dir=/backup/2018-03-13_16-37-59/
innobackupex --apply-log /backup/2018-03-13_16-33-41/
#注意:一定要按照完整备份、第一次增量备份、第二次增量备份的顺序进行整合,在整合最后一次增量备份时不要使用--redo-only参数
开始还原
innobackupex --copy-back /backup/2018-03-13_16-33-41/
#还原成功后你会看到“completed OK!”的字样
启动数据库
启动时候会报错,可以很清楚看出是权限问题,chown -R ...
嗯,使用备份下来的mysql5.7的账号密码可以直接使用
在另外一台服务器上,直接启动加入集群后会自动通不主上的数据,数据量大的情况下肯定是要先备份恢复的