返回
数据
分类

必赢手机登录网址同时可以备份 MyISAM 和 InnoDB,Xtrabackup中包含两个工具

日期: 2020-01-02 07:55 浏览次数 : 73

mysql xtrabackup安装以及简单使用

必赢手机登录网址 1

 

Percona

Xtrabackup 是percona公司的开源项目,用以实现类似innodb官方的热备份工具InnoDB Hot Backup的功能,能够非常快速地备份与恢复mysql数据库。Xtrabackup中包含两个工具:

Xtrabackup是由 Percona 开发的一个开源软件,可实现对 InnoDB 的数据备份,支持在线热备份(备份时不影响数据读写)。备份时,Xtrabackup 会将 Master 的 binlog 信息记录在 xtrabackup_slave_info 文件中,通过此信息可以方便的搭建主从复制。
XtraBackup 有两个工具:xtrabackup 和 innobackupex。xtrabackup 本身只能备份 InnoDB 和 XtraDB ,不能备份 MyISAM;innobackupex 本身是 Hot Backup 脚本修改而来,同时可以备份 MyISAM 和 InnoDB,但是备份 MyISAM 需要加读锁。

xtrabackup是用于热备份innodb和xtradb表中数据的工具,不能备份其他引擎的表,也不能备份数据表结构;

修改MySQL配置文件

Master
# vim /etc/my.cnf //修改主服务器MySQL的配置文件
server-id=1 //master id需要设定为1
log-bin=mysql-bin // mysql bin日志需要打开

Slave
# vim /etc/my.cnf //修改从服务器MySQL的配置文件
server-id=2 //slave id不能设为1

innobackupex是将xtrabackup进行封装的perl脚本,提供了备份myisam表的能力。

安装XtraBackup

yum install http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm //添加源
yum list | grep percona //检查源
yum install percona-xtrabackup

 

创建备份

innobackupex --user=DBUSER --password=DBUSERPASS /path/to/BACKUP-DIR/  

如果执行正确,其输出信息通常类似:

innobackupex: Backup created in directory '/path/to/BACKUP-DIR/2016-03-23_00-00-09'
innobackupex: MySQL binlog position: filename 'mysql-bin.000003', position 1946
111225 00:00:53 innobackupex: completed OK!

备份时,innobackupex 会调用 xtrabackup 备份 InnoDB 表的数据,并且会复制 MyISAM, MERGE,CSV 和 ARCHIVE 表的表定义文件(.frm 文件)、数据文件。同时还会备份触发器和数据库配置信息相关的文件。这些文件将会保存在指定备份目录中一个以时间戳命名的目录下。

[[email protected] ~]# rpm -ivh percona-xtrabackup-2.1.3-608.rhel5.x86_64.rpm 
warning: percona-xtrabackup-2.1.3-608.rhel5.x86_64.rpm: Header V4 DSA signature: NOKEY, key ID cd2efd2a
Preparing...                ########################################### [100%]
   1:percona-xtrabackup     ########################################### [100%]
安装完毕,在/usr/bin 下有如下两个工具innobackupex和xtrabackup 
[email protected] bin]# ll inno* 
-rwxr-xr-x 1 root root 110738 May 23 02:24 innobackupex
lrwxrwxrwx 1 root root     12 Jun  9 18:18 innobackupex-1.5.1 -> innobackupex
[[email protected] bin]# ll *xtrabackup* 
-rwxr-xr-x 1 root root  2894280 May 23 02:25 xtrabackup
-rwxr-xr-x 1 root root  4494952 May 23 02:25 xtrabackup_55
-rwxr-xr-x 1 root root 11633272 May 23 02:25 xtrabackup_56

必赢手机登录网址 ,准备备份

innobackupex --apply-log  /path/to/BACKUP-DIR

如果执行正确,其最后输出的几行信息通常如下:

xtrabackup: starting shutdown with innodb_fast_shutdown = 1
120407 9:01:36 InnoDB: Starting shutdown...
120407 9:01:40 InnoDB: Shutdown completed; log sequence number 92036620
120407 09:01:40 innobackupex: completed OK!

 

恢复备份

将数据恢复到从服务器上:

scp -r /path/to/BACKUP-DIR root@slave_host:/data/

关闭从服务器的mysql服务:

sudo /etc/init.d/mysql stop

在从服务器上恢复备份数据:

innobackupex --copy-back  /path/to/BACKUP-DIR

如果从数据库存在多个mysql,则需要使用以下命令:

innobackupex --defaults-file=/etc/my.cnf --defaults-group=mysqld1 --socket=/var/lib/mysql/mysqld1.sock /path/to/BACKUP-DIR

一个完整的全备过程

信息设置

修改备份数据的用户和组:

chown -R mysql:mysql /path/to/BACKUP-DIR

在主服务上添加同步用的账号:

GRANT REPLICATION SLAVE ON *.* TO 'slave'@'192.168.0.1' IDENTIFIED BY 'slave';

在从服务器上配置同步账号信息:

CHANGE MASTER TO
MASTER_HOST='<master_host>',
MASTER_USER='<slave_username>',
MASTER_PASSWORD='<slave_password>',
MASTER_PORT='<master_port>'
MASTER_LOG_FILE='<see xtrabackup_binlog_info>',
MASTER_LOG_POS=<see xtrabackup_binlog_info>;

开启主从同步:

start slave;

查看状态:

show slave statusG

1 创建一个全备 

参考资料:

  • https://segmentfault.com/a/1190000002575399
  • https://www.percona.com/blog/2014/08/26/mysqld_multi-how-to-run-multiple-instances-of-mysql/
Innobackupex  --user=root  --password=passwd  /root/mysqlbackup/

 

这样就创建了一个全备,备份文件存储在以时间戳为目录名下面,

还有以下选项 

--defaults-file=/etc/my.cnf 备份时使用的mysql配置文件
--no-timestamp 不以时间戳命名目录名

 

2 创建了备份之后,数据还不能用于恢复。一些某提交的事务还可能未撤销或者日志中的事务要重播,为了保证数据一致性,我们需要apply日志到备份的文件上。

 innobackupex --apply-log /root/mysqlbackup/2013-06-14_16-20-56

 

这样备份的数据就可以应用与恢复

3 drop database mysql 然后恢复

 innobackupex --user=root --copy-back /root/mysqlbackup/2013-06-14_16-20-56

 

恢复完毕,改变数据文件的权限,启动数据库

chown  -R mysql:mysql    /usr/local/mysql/data

 

 

需要注意的是,全恢复情况下,

 1 服务器必须关闭,只要部分恢复的时候,服务器不用关闭。

 2 datadir参数目录必须为空,如果存在文件,--copy-back 将不拷贝

  3  每次操作完毕,确认日志最后是否有 innobackupex: completed OK!标志着动作的完成。

xtrabackup安装以及简单使用 Xtrabackup 是percona公司的开源项目,用以实现类似innodb官方的热备份工具InnoDB Hot Backup的功能,能够非常快速地...