用xtrabackup备份mysql数据库方法指导
xtrabackup是由percona提供的mysql备份工具,它是一款物理备份工具,通过连接数据库把数据库的数据备份出来。对于innodb存储引擎其支持全量备份和增量备份。对于myisam存储引擎只支持增量备份。因为xtrabackup对innodb的增量备份是基于表空间的LSN进行的,所谓LSN即:表空间分成多个数据块,每个数据块都有相应的序列号,当数据块数据发生变化则更新序列号。全量备份即备份所有数据块,则增量备份则基于全量备份最后一个数据块的序列号到最新的数据块序列号进行备份。因为myisam不支持表空间,所以不能进行增量备份。
Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具。
Xtrabackup中主要包含两个工具:
xtrabackup:是用于热备份innodb, xtradb表中数据的工具,不能备份其他类型的表,也不能备份数据表结构;
innobackupex:是将xtrabackup进行封装的perl脚本,可以备份和恢复MyISAM表以及数据表结构。
xtrabackup备份出来的数据包括:
表空间
数据文件
二进制日志
事务日志
...
xtrabackup在进行数据恢复之前需要注意如下要点:
如果有增量备份则需要在恢复之前先进行增量备份和全备份的合并再恢复;
如果是支持事务的表的备份,则恢复之前需要先进行事务日志的回滚和提交操作;
如果是多个连续的备份操作,则只需要提交事务日志,不需要回滚,只有在全部备份操作合成之后再进行事务的回滚;
此文通过详细的实验步骤来演示xtrabackup的使用方法。
实验步骤
一台centos7虚拟机,安装mariadb-5.5.52版本的数据库,首先通过sql脚本导入hellodb测试库,其包括一个students数据表,此实验在students表中进行操作,命令如下:
mysql -uroot < hellodb.sql
安装xtrabackup,可以从官方网站下载安装包,然后通过yum进行安装,下载站点为:,此处不再演示安装过程;
xtrabackup的主要命令为innobackupex,通过innobackupex --help或者man手册可以获取到帮助信息;
数据库已经导入,此时可以进行数据库的备份操作,先进行数据库的全量备份和恢复:
xtrabackup_binlog_info:记录二进制日志的内容;
xtrabackup_checkpoints:记录备份类型,开始和结束的lsn编号等备份信息;
xtrabackup_info:记录更详细的备份信息,如是否为所有库备份,是否压缩,备份执行的命令等信息;
xtrabackup_logfile:记录的是事务日志,为二进制文件,不可查看;
首先确保数据库已经开启二进制日志,通过show global variables like 'log_bin';命令可以看到是否已经开启,通过show binary logs;可以看到目前正在使用的二进制日志是哪一个;
通过xtrabackup进行备份,数据备份到/data/backup目录下,备份完成会在指定目录下生成一个以当前时间命名的文件夹:
innobackupex -u root /data/backup
文件夹内容如下:
此时就备份成功了,然后演示数据库的恢复操作。注意:恢复之前需要首先停止数据库服务:
innobackupex --apply-log 2017-07-13_21-02-07/ #首先进行事务日志的提交和回滚 innobackupex --copy-back 2017-07-13_21-02-07/ #进行数据恢复,会自动把数据恢复到mysql的数据目录下
恢复成功之后所有已经恢复数据的属主和属组都是root用户,需要修改成mysql用户才能登陆数据库;
此时登陆数据库即可看到所有数据都已经恢复了。
这次演示增量备份和恢复操作:
生产环境建议二进制日志和数据文件分开放在不同磁盘,因为二进制文件可以用来进行时间点恢复,可以尽可能保证丢失更少的数据,如果二进制文件也丢失,则可能会丢失大量数据;
在数据恢复操作完成之后一定要再进行一次数据的全备份,保证数据安全;
往数据库中插入几条新的信息,然后进行数据库的增量备份;
通过如下命令进行数据库的增量备份,备份成功之后还是会在/data/backup目录下生成一个新的以时间命名的文件夹:
innobackupex -u root -p 1234567a --incremental --incremental-basedir=/data/backup/2017-07-13_21-07-23/ /data/backup/
然后停掉数据库服务,删除数据库目录下的所有数据,进行数据恢复操作,步骤如下:
innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ #进行全量备份的事务提交,但是不回滚未提交事务,因为未提交事务可能在下次的增量备份中提交 innobackupex --apply-log --redo-only 2017-07-13_22-16-19/ --incremental-dir=2017-07-13_22-18-34/ #进行增量备份和全备份的合成已经事务提交工作 innobackupex --apply-log 2017-07-13_22-16-19/ #对于全备份也没有完成的事务进行回滚操作 innobackupex --copy-back 2017-07-13_22-16-19/ #此时采用全备份即可恢复数据,不再需要增量备份,因为已经进行了备份的合成操作
-
同样需要修改恢复完成数据的属主和属组,然后登陆数据库即可看到完整是数据,此时实验演示完成。
注意:
以上是用xtrabackup备份mysql数据库方法指导的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

MySQL在Web应用中的主要作用是存储和管理数据。1.MySQL高效处理用户信息、产品目录和交易记录等数据。2.通过SQL查询,开发者能从数据库提取信息生成动态内容。3.MySQL基于客户端-服务器模型工作,确保查询速度可接受。

在 Docker 中启动 MySQL 的过程包含以下步骤:拉取 MySQL 镜像创建并启动容器,设置根用户密码并映射端口验证连接创建数据库和用户授予对数据库的所有权限

Laravel 是一款 PHP 框架,用于轻松构建 Web 应用程序。它提供一系列强大的功能,包括:安装: 使用 Composer 全局安装 Laravel CLI,并在项目目录中创建应用程序。路由: 在 routes/web.php 中定义 URL 和处理函数之间的关系。视图: 在 resources/views 中创建视图以呈现应用程序的界面。数据库集成: 提供与 MySQL 等数据库的开箱即用集成,并使用迁移来创建和修改表。模型和控制器: 模型表示数据库实体,控制器处理 HTTP 请求。

在开发一个小型应用时,我遇到了一个棘手的问题:需要快速集成一个轻量级的数据库操作库。尝试了多个库后,我发现它们要么功能过多,要么兼容性不佳。最终,我找到了minii/db,这是一个基于Yii2的简化版本,完美地解决了我的问题。

MySQL和phpMyAdmin是强大的数据库管理工具。1)MySQL用于创建数据库和表、执行DML和SQL查询。2)phpMyAdmin提供直观界面进行数据库管理、表结构管理、数据操作和用户权限管理。

文章摘要:本文提供了详细分步说明,指导读者如何轻松安装 Laravel 框架。Laravel 是一个功能强大的 PHP 框架,它 упростил 和加快了 web 应用程序的开发过程。本教程涵盖了从系统要求到配置数据库和设置路由等各个方面的安装过程。通过遵循这些步骤,读者可以快速高效地为他们的 Laravel 项目打下坚实的基础。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

MySQL适合Web应用和内容管理系统,因其开源、高性能和易用性而受欢迎。1)与PostgreSQL相比,MySQL在简单查询和高并发读操作上表现更好。2)相较Oracle,MySQL因开源和低成本更受中小企业青睐。3)对比MicrosoftSQLServer,MySQL更适合跨平台应用。4)与MongoDB不同,MySQL更适用于结构化数据和事务处理。
