MySQL数据备份与恢复_MySQL
一.备份数据的方式
MySQL参数说明:http://www.linuxidc.com/Linux/2014-04/99673.htm
MySQL管理之数据备份及恢复http://www.linuxidc.com/Linux/2014-04/99674.htm
1.物理备份
1.1冷备 cp tar等
1.2热备 mysqlhotcopy 只能备份存储引擎是myisam的表,依赖perl-DBD-MySQL
2.逻辑备份:用mysql自己提供的备份命令或第三放方软件提供的备份命令,备份创建库、表、和产生表记录时的sql语句。
二.数据备份策略:
1.完整备份 备份数据库服务器上的所有库所有表。
2.差异备份 备份自完整备份后所有产生的新数据。
3.增量备份 备份自上一次备份后所有产生的新数据
生产环境一般采用 完整备份 增量备份 或者 完整备份 差异备份
三.逻辑备份与恢复
1.mysqldump命令做数据的完整备份
命令格式:
mysqldump -h数据库服务器ip -u用户名 -p密码 数据库名 > 目录名/备份文件名
数据库名的表示方式:
--all-databases 备份数据库服务器上的所有库所有表
数据库名 对某个库做完整备份
数据库名 表 对指定库里的指定表做完整备份
-B 数据库名1 数据库名2 数据库N 对某几个库做完整备份
#目录名 :若备份时不写目录名备份文件就存放在,执行备份命令时 所在的目录下
#备份文件名 :可以自己定义,要有标识性,约定俗成mysql的备份文件都以.sql 结尾
若文件重名,上一次备份会被当前备份覆盖。
# 备份用来连接数据库服务器的用户,要有被备份的目标库有相应的权限才可以。
2.恢复完整备份数据
命令格式:
mysql -h数据库服务器ip -u用户名 -p密码 数据库名 < 目录名/xxx.sql
mysql -h数据库服务器ip -u用户名 -p密码 < 目录名/xxx.sql
# 数据库名:可选项,当备份文件中有 create database,use sql语句时,恢复数据时可以不指定数据库名。
# 用完整备份文件 恢复数据,只能把数据恢复到备份时的状态,完整备份之后产生的信息数据是无法恢复。
四.使用binlog日志做增量备份与数据恢复
1.mysql日志类型
mysql共有4种类型日志:
binlog日志(二进制日志) 记录除查询之外sql语句。
错误日志 记录mysql服务在启动和运行过程中产生的错误。
查询日志 记录执行的所有的sql操作。
慢查询日志 只记录超过指定时间,显示查询结果的sql语句。默认超时时间是10秒。
#默认情况下,mysql只开启错误日志。
#默认情况下日志都存放在数据库目录下。每种日志文件都默认命名方式。
2.启用binlog日志
vim /etc/my.cnf
[mysqld]
log_bin=/binlogdir/filename //设置存放binlog目录和文件名,自定义目录必须让mysql用户有写入权限,目录不设置则默认在数据库目录/var/lib/mysql/下,文件名不设置则默认为:主机名-bin.000001
max-binlog-size=100M //设置binlog日志文件的大小,不设置则默认为500M自动生成第二个binlog日志文件
service mysql restart
# 对所有库操作的使用数据发送改变的sql语句都会写进当前编号最大的binlog日志文件里。
# localhost-bin.index 记录当前已有binlog日志文件
3.分析binlog日志文件内容。
binlog日志记录sql语句的方式:
① 时间方式
② 字符偏移量方式
mysqlbinlog [选项] binlog日志文件名
选项:
偏移量
--start-position=100 起始位置
--stop-position=1200 结束位置
时间点:
--start-datetime="YYYY-mm-dd HH:MM:SS" 起始时间
--stop-datetime="YYYY-mm-dd HH:MM:SS" 结束时间
# 不加任何选项则默认查看全部日志内容
4.手动生成新的binlog日志文件方式:
① mysql>flush logs;
② #mysql -h数据库服务器IP -u用户名 -p密码 -e "flush logs"
③ #mysqldump -h数据库服务器IP -u用户名 -p密码 --flush-logs 数据库名> /目录名/xxx.sql
④ service mysql restart //一般不用
5.增量备份数据恢复
原理:使用mysqlbinlog提取历史sql操作管道给mysql命令重做
命令格式:
mysqlbinlog [选项] binlog日志文件名 | mysql -h数据库服务器ip -u用户名 -p密码 数据库名
批量恢复增量备份:
mysqlbinlog `cat localhost-bin.index`| mysql -h数据库服务器ip -u用户名 -p密码 [数据库名]
6.清理binlog日志
删除早于指定编号的binlog日志文件:
mysql> PURGE MASTER LOGS TO 'binlog日志文件名';
删除所有binlog日志文件,重建新日志:
mysql> RESET MASTER;
更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2014-05/102266p2.htm

热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中可能比使用索引更快,具体情况包括:1)数据量较小时;2)查询返回大量数据时;3)索引列不具备高选择性时;4)复杂查询时。通过分析查询计划、优化索引、避免过度索引和定期维护表,可以在实际应用中做出最优选择。

InnoDB的全文搜索功能非常强大,能够显着提高数据库查询效率和处理大量文本数据的能力。 1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。 2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。 3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

是的,可以在 Windows 7 上安装 MySQL,虽然微软已停止支持 Windows 7,但 MySQL 仍兼容它。不过,安装过程中需要注意以下几点:下载适用于 Windows 的 MySQL 安装程序。选择合适的 MySQL 版本(社区版或企业版)。安装过程中选择适当的安装目录和字符集。设置 root 用户密码,并妥善保管。连接数据库进行测试。注意 Windows 7 上的兼容性问题和安全性问题,建议升级到受支持的操作系统。

聚集索引和非聚集索引的区别在于:1.聚集索引将数据行存储在索引结构中,适合按主键查询和范围查询。2.非聚集索引存储索引键值和数据行的指针,适用于非主键列查询。

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

MySQL 和 MariaDB 可以共存,但需要谨慎配置。关键在于为每个数据库分配不同的端口号和数据目录,并调整内存分配和缓存大小等参数。连接池、应用程序配置和版本差异也需要考虑,需要仔细测试和规划以避免陷阱。在资源有限的情况下,同时运行两个数据库可能会导致性能问题。

MySQL支持四种索引类型:B-Tree、Hash、Full-text和Spatial。1.B-Tree索引适用于等值查找、范围查询和排序。2.Hash索引适用于等值查找,但不支持范围查询和排序。3.Full-text索引用于全文搜索,适合处理大量文本数据。4.Spatial索引用于地理空间数据查询,适用于GIS应用。
