用xtrabackup实现mysql的主从复制

参考https://segmentfault.com/a/1190000003063874

如果我们用传统的mysqldump来实现mysql主从,期间我们需要锁库,如果是线上环境会影响运行,所以我们用xtrabackup来实现mysql主从配置。

XtraBackup的优点

  1. 可以快速可靠的完成数据备份(复制数据文件和追踪事务日志)
  2. 数据备份过程中不会中断事务的处理(热备份)
  3. 节约磁盘空间和网络带宽
  4. 自动完成备份鉴定
  5. 因更快的恢复时间而提高在线时间

一.命令安装:

yum install -y gnupg
rpm -Uhv http://www.percona.com/downloads/percona-release/percona-release-0.0-1.x86_64.rpm(64位源)
rpm -Uhv https://www.percona.com/redir/downloads/percona-release/percona-release-0.0-1.i386.rpm(32位源)
yum install -y percona-xtrabackup
[[email protected] ~]# xtrabackup -v
xtrabackup version 2.3.3 based on MySQL server 5.6.24 Linux (x86_64) (revision id: 525ca7d)

二 mysql配置

1. Master:/etc/my.cnf
加上 datadir=/~~~~~~
server-id
log-bin
2. Slave:/etc/my.cnf
server-id=2
datadir=/var/lib/mysql

3. Master:在master数据库设置用来同步的slave用户权限

 grant replication slave on *.* to ‘repl‘@‘192.168.75.128‘ identified by ‘123123‘;

(从的主机ip,并且建立一个同步的用户repl)

4 master:导出数据  (默认是备份所有的数据库)

 innobackupex  --defaults-file=/etc/my.cnf  --user=root --password=123456  /data/backup

innobackupex: Backup created in directory ‘/data/backup/2012-04-19_10-46-32‘ 
innobackupex: MySQL binlog position: filename ‘log_bin.000027‘, position 2973624 
120419 10:46:53  innobackupex: completed OK! 
最后输出 completed OK! 表示备份成功了。

备份好的文件保存在 /data/backup目录中,比如: 
/data/backup/2012-04-19_10-46-32/ 
[[email protected] ~]# ls /data/backup/2012-04-19_10-46-32/ 
backup-my.cnf ibdata1 mysql shipincon test xtrabackup_binary xtrabackup_binlog_info xtrabackup_checkpoints xtrabackup_logfile 
 
备份日志: 
刚刚备份好的数据文件,并不是直接可用的。需要再恢复一下

[[email protected] ~]#  

innobackupex   --apply-log   /data/backup/2012-04-19_10-46-32/


5 把恢复好的数据拷贝到slave上面

scp -r /data/backup/2012-04-19_10-46-32/ [email protected]:/data/


关闭从服务器并切换数据: 

然后倒入数据库

innobackupex   --defaults-file=/etc/my.cnf  --copy-back  2012-04-19_10-46-32

最后记得更改属主和属组 mysql ,否则无法重启

chown -R mysql:mysql *
然后启动mysqld:  
/etc/init.d/mysql start


与mysqldump备份的步骤比起来,这次我们没有flush tables with read lock, 
也没有show master status来获取日志文件名和座标。

因为xtrabackup完成备份之后,自动保存了这些信息。

我们查看备份里面的一个文件 cat   xtrabackup_binlog_info  里面有

mysql-bin.000008        120


最后一步,登录到slave数据库上面

stop slave;
change master to master_host=‘10.171.132.57‘, master_port=3306, master_user=‘repl‘, master_password=‘123123‘, master_log_file=‘mysql-bin.000008‘, master_log_pos=120;
start slave;
show slave status\G;查看信息

如果出现两个yes代表成功了


测试:主上面可以删除或者创建表

创建huningfei这个表  create table huningfei (id int(10) ,name varchar(10));

删除drop tables huningfei;

时间: 2024-10-07 02:18:29

用xtrabackup实现mysql的主从复制的相关文章

使用 Xtrabackup 在线对MySQL做主从复制【转】

1. 说明 1.1 xtrabackup mysqldump对于导出10G以下的数据库或几个表,还是适用的,而且更快捷.一旦数据量达到100-500G,无论是对原库的压力还是导出的性能,mysqldump就力不从心了.Percona-Xtrabackup备份工具,是实现MySQL在线热备工作的不二选择,可进行全量.增量.单表备份和还原.(但当数据量更大时,可能需要考虑分库分表,或使用 LVM 快照来加快备份速度了) 2.2版本 xtrabackup 能对InnoDB和XtraDB存储引擎的数据库

使用xtrabackup实现MySQL主从复制

环境描述 主从环境 项目 Master Slave OS版本 SuSE 11sp1 x86_64 SuSE 11sp1 x86_64 MySQL版本 官方版本5.5.37 官方版本5.5.37 hostname NDMC74 NDMC75 IP 192.168.223.132 192.168.223.133 PORT 3306 3306 server-id 1323306 1333306 参数文件 /etc/my.cnf /etc/my.cnf DATADIR /data/mysql/mysql

MySQL Replication 主从复制全方位解决方案

原文:MySQL Replication 主从复制全方位解决方案 1.1 主从复制基础概念 在了解主从复制之前必须要了解的就是数据库的二进制日志(binlog),主从复制架构大多基于二进制日志进行,二进制日志相关信息参考:http://www.cnblogs.com/clsn/p/8087678.html#_label6 1.1.1 二进制日志管理说明 二进制日志在哪?如何设置位置和命名? 在my.cnf文件中使用 log-bin = 指定:命名规则为 mysql-bin.000000 (后为6

mysql实现主从复制

今天说一下MySQL的主从复制如何做到! 准备工作: 1.两个虚拟机:我这里用的是CentOS5.5,IP地址分别是192.168.1.101 和192.168.1.105: 101做主服务器,105做从服务器(都已经安装相同版本的Mysql): 2.本机环境:Apache+PHP+MySQL 好了,现在开始吧,来看看这听起来高大上的主从复制是怎么回事. 原理:mysql要做到主从复制,其实依靠的是二进制日志,即:假设主服务器叫A,从服务器叫B:主从复制就是   B跟着A学,A做什么,B就做什么

xtrabackup进行MySQL数据库备份/还原

http://hongge.blog.51cto.com/ 使用xtrabackup进行MySQL数据库备份 前面介绍mysqldump备份方式是采用逻辑备份,其最大的缺陷就是备份和恢复速度都慢,对于一个小于50G的数据库而言,这个速度还是能接受的,但如果数据库非常大,那再使用mysqldump备份就不太适合了. 这时就需要一种好用又高效的工具,xtrabackup就是其中一款,号称免费版的InnoDB HotBackup. Xtrabackup实现是物理备份,而且是物理热备 目前主流的有两个工

利用XtraBackup实现MySQL物理备份恢复

Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具.特点: (1)备份过程快速.可靠: (2)备份过程不会打断正在执行的事务: (3)能够基于压缩等功能节约磁盘空间和流量: (4)自动实现备份检验: (5)还原速度快: Xtrabackup中主要包含两个工具: xtrabackup:是用于热备份innodb, xtradb表中数据的工具,不能备份其他类型的表,也不能备份数据表结构: in

怎样解决MySQL数据库主从复制延迟的问题?

1.网络超时 2.慢查询 3.流量 问题一:主库的从库太多,导致复制延迟从库数据以3-5个为宜,要复制的从节点数量过多,会导致复制延迟问题二:从库硬件比主库差,导致复制延迟查看Master和Slave的系统配置,可能会因为机器配置不当,包括磁盘I/O.CPU.内存等各方面因素造成复制的延迟.一般发生在高并发大数据量写入场景中问题三:慢SQL语句过多假如一条SQL语句执行时间是20秒,那么从执行完毕到从库上能查到数据至少需要20秒,这样就延迟20秒了.一般要把SQL语句的优化作为常规工作不断地进行

用python监控mysql的主从复制

利用python来检查MySQL的主从复制, 有一个注意点是,cur.execute("show slave status;") 不能用cur.execute("show slave status\G;") result = cur.fetchall() 返回的是个二元数组 result[0] 返回时整个show slave status 状态信息. result[0][n] 返回具体的某一项. python代码如下: #!/usr/bin/env python #

MySQL的主从复制是如何实现的

前言 MySQL的主从复制是MySQL本身自带的一个功能,不需要额外的第三方软件就可以实现,其复制功能并不是copy文件来实现的,而是借助binlog日志文件里面的SQL命令实现的主从复制,可以理解为我再Master端执行了一条SQL命令,那么在Salve端同样会执行一遍,从而达到主从复制的效果. MySQL主从复制架构图 一主一从 master-slave-replication-01 一主多从 master-slave-replication-02 级联 master-slave-repli