mysql中xtrabackup原理、备份日志分析、备份信息获取的案例分析
发布时间:2022-01-11 01:47:28 所属栏目:MySql教程 来源:互联网
导读:小编给大家分享一下mysql中xtrabackup原理、备份日志分析、备份信息获取的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 一、 xtrabackup备份恢复工作原理: Inn
![]() 小编给大家分享一下mysql中xtrabackup原理、备份日志分析、备份信息获取的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 一、 xtrabackup备份恢复工作原理: InnoDB引擎很大程度上与Oracle类似,使用redo,undo机制,XtraBackup在备份的时候,以read-write模式打开innodb的数据文件,然后对其进行复制。与此同时,XtraBackup还有另外一个线程监视着transactions log,一旦log发生变化,就把变化过的log pages复制走,直到全部innoDB数据文件复制完成之后,停止监控log buffer及日志复制。如果log buffer没有及时写出将被日志的循环写特性覆盖。xtrabackup在启动时会记住log sequence number(LSN),然后一页一页地复制InnoDB的数据。 xtrabackup在恢复期间对提交的事务前滚,未提交或失败的事务进行回滚,从而保证数据的一致性。因此对于InnoDB表在备份期间不会锁表。由于XtraBackup其内置的InnoDB库打开文件的时候是rw的,所以运行XtraBackup的用户,必须对InnoDB的数据文件具有读写权限。 补充: 1. 在备份innodb page的过程中,XtraBackup每次读写1MB的数据,1MB/16KB=64个page。这个不可配置。读1MB数据之 后,XtraBackup一页一页地遍历这1MB数据,使用innodb的buf_page_is_corrupted()函数检查此页的数据是否正常, 如果数据不正常,就重新读取这一页,最多重新读取10次,如果还是失败,备份就失败了,退出。在复制transactions log的时候,每次读写512KB的数据。同样不可以配置。 2. 如果要使用一个最小权限的用户进行备份,则可基于如下命令创建此类用户: mysql> CREATE USER 'bkuser'@'localhost' IDENTIFIED BY 'secret'; mysql> REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'bkuser'; mysql> GRANT RELOAD, LOCK TABLES, REPLICATION CLIENT ON *.* TO 'bkuser'@'localhost'; mysql> FLUSH PRIVILEGES; 二、 获取备份的相关信息 1. 查看备份期间生成的文件 [root@mysql01 full]# ls /xtrabackup/full/2017-06-02_20-24-02/ backup-my.cnf performance_schema xtrabackup_checkpoints ibdata1 test xtrabackup_info mysql xtrabackup_binlog_info xtrabackup_logfile 说明: 2. 查看备份有关的总体信息 [root@mysql01 full]# more /xtrabackup/full/2017-06-02_20-24-02/xtrabackup_info uuid = 5e8841af-478e-11e7-a0d7-000c2944297a name = tool_name = innobackupex tool_command = --user=root --password=... /xtrabackup/full/ tool_version = 2.4.7 ibbackup_version = 2.4.7 server_version = 5.6.25-log start_time = 2017-06-02 20:24:02 end_time = 2017-06-02 20:24:05 lock_time = 0 binlog_pos = filename 'binlog.000001', position '120' innodb_from_lsn = 0 innodb_to_lsn = 1626057 partial = N 说明>xtrabackup_info 记录: 整个备份信息的概要 3. 查看备份检查点的相关信息 [root@mysql01 full]# more /xtrabackup/full/2017-06-02_20-24-02/xtrabackup_checkpoints backup_type = full-backuped from_lsn = 0 to_lsn = 1626057 last_lsn = 1626057 compact = 0 recover_binlog_info = 0 说明>xtrabackup_checkpoints 记录:备份类型(如完全或增量)、备份状态(如是否已经为prepared状态)和LSN(日志序列号)范围信息; 4. 查看备份binlog有关的信息 [root@mysql01 full]# more /xtrabackup/full/2017-06-02_20-24-02/xtrabackup_binlog_info binlog.000001 120 说明>xtrabackup_binlog_info记录: mysql服务器当前正在使用的二进制日志文件及至备份这一刻为止二进制日志事件的位置。 5. 查看备份命令的配置选项信息 [root@mysql01 full]# more /xtrabackup/full/2017-06-02_20-24-02/backup-my.cnf # This MySQL options file was generated by innobackupex. # The MySQL server [mysqld] innodb_checksum_algorithm=innodb innodb_log_checksum_algorithm=innodb innodb_data_file_path=ibdata1:12M:autoextend innodb_log_files_in_group=2 innodb_log_file_size=50331648 innodb_fast_checksum=false innodb_page_size=16384 innodb_log_block_size=512 innodb_undo_directory=. innodb_undo_tablespaces=0 以上是“mysql中xtrabackup原理、备份日志分析、备份信息获取的示例分析”这篇文章的所有内容,感谢各位的阅读! (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |