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的账号密码可以直接使用
在另外一台服务器上,直接启动加入集群后会自动通不主上的数据,数据量大的情况下肯定是要先备份恢复的
MySQL集群-PXC搭建以及使用innobackupex工具进行全局备份和增量备份的更多相关文章
- MySQL集群PXC的搭建
MySQL集群PXC的搭建 最近公司某客户要求我们的数据库搭建PXC集群以保证他们的系统高性能和搞稳定性 以后花费了一些时间去搭建和测试,也踩过一些坑,准备分享出来 系统:centos6.6PXC:5 ...
- MYSQL集群的搭建
按照此配置完全可以配置成功!! 一.介绍========测试环境:Server1:ndbd 192.168.1.225Server2:ndbd 192.168.1.226Server3:mysqld ...
- docker 下 mysql 集群的搭建
下载程序&&创建docker容器 从mysql官网https://dev.mysql.com/downloads/cluster/上下载mysql集群库mysql-cluster-gp ...
- Mysql 集群环境搭建
在上一篇文章中已经详细的写了关于Mysql的安装步骤.这一篇文章在上一篇文章的基础之上接着写集群的安装与部署. 安装地址:https://www.cnblogs.com/ming-blogs/p/10 ...
- MySQL集群(PXC)入门
一.学习动机 伴随互联网行业的兴起,越来越多的领域需要相应的技术方案,比如:打出软件.电商平台.直播平台.电子支付.媒体社交. 身边常见的,校园出成绩那一年,我们会感觉网站异常的卡顿,因为访问人数太多 ...
- 数据切分——Atlas读写分离Mysql集群的搭建
关于数据切分的原理可以参见博客: http://blog.csdn.net/jhq0113/article/details/44226789 关于Atlas的介绍可以参见博客: http://blog ...
- 项目进阶 之 集群环境搭建(三)多管理节点MySQL集群
上次的博文项目进阶 之 集群环境搭建(二)MySQL集群中,我们搭建了一个基础的MySQL集群,这篇博客咱们继续讲解MySQL集群的相关内容,同时针对上一篇遗留的问题提出一个解决方案. 1.单管理节点 ...
- [原]项目进阶 之 集群环境搭建(二)MySQL集群
上次的博文中我们介绍了一下集群的相关概念,今天的博文我们介绍一下MySQL集群的相关内容. 1.MySQL集群简介 MySQL群集技术在分布式系统中为MySQL数据提供了冗余特性,增强了安全性,使得单 ...
- windows+mysql集群搭建-三分钟搞定集群
注:本文来源: 陈晓婵 < windows+mysql集群搭建-三分钟搞定集群 > 一:mysql集群搭建教程-基础篇 计算机一级考试系统要用集群,目标是把集群搭建起来,保证一 ...
随机推荐
- 关于NativeEvent的处理
nativeEvent(const QByteArray &eventType, void *message, long *result){ chASSERT(message != NULL) ...
- 用CSS写扫描二维码图标
代码如下: <style>.icon{margin:300px;width:30px;height:30px;position:relative}.icon .b{border:2px s ...
- January 17 2017 Week 3 Tuesday
You can't shake hands with a clenched fist. 紧握拳头你就无法与他人握手. If you want to shake hands with others, j ...
- zt C++ list 类学习笔记
C++ list 类学习笔记 分类: C++ 2011-09-29 00:12 7819人阅读 评论(0) 收藏 举报 listc++iteratorvectorcconstructor 双向循环链表 ...
- 在一个Excel单元格内输入多行内容
有时候,我们想在一个Excel单元格中输入多行内容,可以根据不同情况选择下面的方法来实现: 方法一:如果有大量的单元格需要这样做,采取此种设置格式的方法,选中需要这种格式的单元格,执行“格式→单元格” ...
- MySQL语法三:数据控制语句
数据控制语句MCL(GRANT,REVOKE,COMMIT,ROLLBACK)
- (fields.E130) DecimalFields must define a 'decimal_places' attribute.
DecimalField类型:固定精度的十进制数,一般用来存金额相关的数据.额外的参数包括DecimalField.max_digits(整个数字的长度)和DecimalField.decimal_p ...
- Django 按时间来查找数据库中的数据
问题: 按时间来查找数据表中的数据. 前提: 1. 数据表student中有一个字段类型为DateField或者DateTimeField字段, 字段名是birthday. 2. 数据表中已经有些数据 ...
- HDOJ 1528 Card Game Cheater
版权声明:来自: 码代码的猿猿的AC之路 http://blog.csdn.net/ck_boss https://blog.csdn.net/u012797220/article/details/3 ...
- HDU 1735 字数统计(模拟+一点点贪心的思想)
题目戳我 字数统计 Time Limit: 1000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...