MySQL集群-PXC搭建以及使用innobackupex工具进行全局备份和增量备份

时间:2023-03-09 04:05:39
MySQL集群-PXC搭建以及使用innobackupex工具进行全局备份和增量备份

环境: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的账号密码可以直接使用

在另外一台服务器上,直接启动加入集群后会自动通不主上的数据,数据量大的情况下肯定是要先备份恢复的