Percona XtraBackup不锁库搭建slave数据库-基于GTID
Percona XtraBackup不锁库搭建slave数据库-基于GTID
1、下载安装epel源并安装
wget http://ftp.cuhk.edu.hk/pub/linux/fedora-epel//6/x86_64/epel-release-6-8.noarch.rpm
rpm -ivh epel-release-6-8.noarch.rpm
yum clean all
2、下载并安装XtraBackup
tar xf Percona-XtraBackup-2.2.7-r5050-el6-x86_64-bundle.tar
yum install percona-xtrabackup-* -y
[root@ip ~]# which xtrabackup
/usr/bin/xtrabackup
现在xtrabackup已经安装完成,
3、在主库上创建复制账号
mysql>grant replication slave on *.* to 'name'@'IP' identified by 'password';
4、接下来就使用xtrabackup做数据库全备
mkdir /data/backup -p
innobackupex --user=root --password='password' --defaults-file=/etc/my.cnf /data/backup/ > /root/back.log 2>&1
注:将执行过程重定向到back.log文件中,待执行完成后可查看是否有报错,如果没有报错并在文件最后结尾处有如下提示测表示备份成功。
141225 08:18:41 innobackupex: Connection to database server closed
141225 08:18:41 innobackupex: completed OK!
备份好的文件保存在 /data/backup目录中,比如:
[root@ip ~]# ls /data/backup/
2014-12-25_08-17-23
[root@ip ~]# ls /data/backup/2014-12-25_08-17-23/
backup-my.cnf ibdata2 ib_logfile1 mysql performance_schema xtrabackup_binlog_pos_innodb xtrabackup_info
ibdata1 ib_logfile0 lost+found oneplus_account xtrabackup_binlog_info xtrabackup_checkpoints xtrabackup_logfile
[root@ip ~]#
备份日志:
刚刚备份好的数据文件,并不是直接可用的。现在要将其恢复:
innobackupex --apply-log /data/backup/2014-12-25_08-17-23/ > /root/bb.log 2>&1
这个过程与数据库挂掉之后重启mysqld时的自动修复过程差不多。
scp -r /data/backup/2014-12-25_08-17-23 root@xxxxxx:/data/backup/
关闭从服务器并切换数据:
/etc/init.d/mysql stop
将原来的数据做一下备份
mkdir -p /data/backup/mysql_old
mv /var/lib/mysql/* /data/backup/mysql_old
mv /data/backup/2014-12-25_08-17-23/* /var/lib/mysql/
chown -R mysql.mysql /var/lib/mysql
修改my.cnf, 给它一个独一无二的server_id。
再将从库原来的my.cnf备份
cp /etc/my.cnf /etc/my.cnf.bak
cd /var/lib/mysql/
/bin/cp backup-my.cnf /etc/my.cnf
再将原来my.cnf.bak中的一些参数添加到my.cnf中并启动mysql
/etc/init.d/mysql start
最后change master。
与mysqldump备份的步骤比起来,这次我们没有flush tables with read lock,
也没有show master status来获取日志文件名和座标。
因为xtrabackup完成备份之后,自动保存了这些信息。
采用GTID建立主从关系
可查看在主库上备份时执行过程25.log.查看到UUID和tran_id
[root@ip ~]# cat /var/lib/mysql/xtrabackup_binlog_info
50937877-8987-11e4-88fe-005056a30e51:1-7605
这个时候,登录到服务器,执行如下操作:
reset master;
清楚binlog和tran_id信息.
之所以这样做,是因为原来的mysql实例有自己相应的"uuid+tran_id",如果不清除,就不能完成下面这一步.
同时这里运行reset master.并不会清除其他mysql实例的信息,他只会清除他自身的GTID信息!
SET GLOBAL gtid_purged="50937877-8987-11e4-88fe-005056a30e51:1-7605";
GTID从7606开始传输
最后,开始同步
CHANGE MASTER TO
MASTER_HOST='<master_host>',
MASTER_USER='<slave_username>',
MASTER_PASSWORD='<slave_password>',
MASTER_AUTO_POSITION = 1;
start slave;
通过show slave status\G;可以查看到 Slave_IO_Running和 Slave_SQL_Running状态都为YES,并且Exec_Master_Log_Pos和 Relay_Log_Space数据不断在变化。
至此通过XtraBackup不锁库搭建slave数据库已经完成。
注意:
1.采取这种方式进行mysql数据库主从建立,在传输同步文件的时间上有要求,尽量快速完成,防止gtid 事务号过期
Percona XtraBackup不锁库搭建slave数据库-基于GTID的更多相关文章
- Percona备份mysql全库及指定数据库(完整备份与增量备份)
Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份) Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对I ...
- 5.7 并行复制配置 基于GTID 搭建中从 基于GTID的备份与恢复,同步中断处理
5.7 并行复制配置 基于GTID 搭建中从 基于GTID的备份与恢复,同步中断处理 这个文章包含三个部分 1:gtid的多线程复制2:同步中断处理3:GTID的备份与恢复 下面文字相关的东西 大部分 ...
- xtrabackup在线备份主库,搭建slave,使用gtid模式
mysql:5.6.29xtrabackup:2.2.10master:192.168.166.129slave:192.168.166.131mysql数据目录:/data/mysqlmysql备份 ...
- Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)
原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对In ...
- Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)
Percona Xtrabackup备份mysql大数据库(完整备份与增量备份) 文章目录 [隐藏] Xtrabackup简介 Xtrabackup安装 Xtrabackup工具介绍 inno ...
- 每天进步一点点——mysql——Percona XtraBackup(innobackupex)
一. 简单介绍 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对InnoDB和XtraDB存储引擎的数据库非堵塞地备份(对于MyISAM的备份相同须要加表锁).Xt ...
- Percona Xtrabackup备份mysql(转)
add by zhj:另外,参考了Xtrabackup之innobackupex备份恢复详解,我用的是Xtrabackup2.2.6版本, 可以成功备份和恢复指定的数据库. 原文:http://www ...
- 使用Percona Xtrabackup创建MySQL slave库
一.使用Percona Xtrabackup创建MySQL slave库 MySQL Server 版本: Server version: 5.7.10-log MySQL Community Ser ...
- 通过 XtraBackup 实现不停机不锁表搭建主从同步
简介 Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写).备份时,Xtrabackup 会将 Master 的 b ...
随机推荐
- Win Oracle 监听文件配置参考
Win lister.ora配置参考 # listener.ora Network Configuration File: C:\app\Administrator\product\\dbhome_1 ...
- 移动端,ajax 动态加载的元素,为动态添加的一系列同个类名的元素添加点击事件
背景:一个列表页,有一系列同类名的元素,需要为每一个动态添加的列表项添加事件: 点击选择下图中不同的文档类型,再通过 ajax 动态加载不同的文档. 使用过的方法: 1.通知 jquery 的 $(s ...
- pytest-conftest.py作用范围
1.conftest.py解释 conftest.py是pytest框架里面一个很重要的东西,它可以在这个文件里面编写fixture,而这个fixture的作用就相当于我们unittest框架里面的s ...
- idea 导入svn中java WEB项目
1.打开idea 2.填写svn路径 3.指定本地路径 4.选择1.8 format 5.添加jdk 6.配置tomcat启动项目 File -- Project Structure
- USER 指定当前用户,希望以某个已经建立好的用户来运行某个服务进程,不要使用 su 或者 sudo,这些都需要比较麻烦的配置,而且在 TTY 缺失的环境下经常出错。建议使用 gosu
USER 指定当前用户 格式:USER <用户名>[:<用户组>] USER 指令和 WORKDIR 相似,都是改变环境状态并影响以后的层.WORKDIR 是改变工作目录,US ...
- Vue——前端生成二维码
与后端生成二维码相比,前端生成二维码更具有灵活性,下面就介绍两种前端生成二维码的方式,两种方式相比之下,vue-qr比qrcode多了一个再中间添加logo的功能. 方式一:qrcode npm np ...
- 吴裕雄 python 神经网络——TensorFlow 数据集高层操作
import tempfile import tensorflow as tf train_files = tf.train.match_filenames_once("E:\\output ...
- 临时解决执行 Composer Install 返回 Killed 的问题
昨天在 Linux 服务器上部署 PHP 项目时遇到了一个问题,系统为 Centos 7 ,1 核 1G 的配置.通过 Git 拉取代码后,由于是基于 Laravel 框架的项目,所以需要使用 Com ...
- lc 0228
目录 ✅ 412. Fizz Buzz 描述 解答 c数字转字符: other's c my c tdo py ✅ 235. 二叉搜索树的最近公共祖先 描述 解答 评价者 思路: c py ✅ 412 ...
- Laravel Vuejs 实战:开发知乎 (1)项目环境配置和用户表设计
1.使用laragon新建laravel项目 zhihu 2.配置env文件的database设置 DB_DATABASE=zhihu 3.分析users表需要的字段 4.修改数据库迁移文件: cla ...