一.备份数据的方式
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密码 数据库名
mysql -h数据库服务器ip -u用户名 -p密码
# 数据库名:可选项,当备份文件中有 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

MySQL适合初学者学习数据库技能。1.安装MySQL服务器和客户端工具。2.理解基本SQL查询,如SELECT。3.掌握数据操作:创建表、插入、更新、删除数据。4.学习高级技巧:子查询和窗口函数。5.调试和优化:检查语法、使用索引、避免SELECT*,并使用LIMIT。

MySQL通过表结构和SQL查询高效管理结构化数据,并通过外键实现表间关系。1.创建表时定义数据格式和类型。2.使用外键建立表间关系。3.通过索引和查询优化提高性能。4.定期备份和监控数据库确保数据安全和性能优化。

MySQL是一个开源的关系型数据库管理系统,广泛应用于Web开发。它的关键特性包括:1.支持多种存储引擎,如InnoDB和MyISAM,适用于不同场景;2.提供主从复制功能,利于负载均衡和数据备份;3.通过查询优化和索引使用提高查询效率。

SQL用于与MySQL数据库交互,实现数据的增、删、改、查及数据库设计。1)SQL通过SELECT、INSERT、UPDATE、DELETE语句进行数据操作;2)使用CREATE、ALTER、DROP语句进行数据库设计和管理;3)复杂查询和数据分析通过SQL实现,提升业务决策效率。

MySQL的基本操作包括创建数据库、表格,及使用SQL进行数据的CRUD操作。1.创建数据库:CREATEDATABASEmy_first_db;2.创建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入数据:INSERTINTObooks(title,author,published_year)VA

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

构建MySQL数据库的步骤包括:1.创建数据库和表,2.插入数据,3.进行查询。首先,使用CREATEDATABASE和CREATETABLE语句创建数据库和表,然后用INSERTINTO语句插入数据,最后用SELECT语句查询数据。

MySQL适合初学者,因为它易用且功能强大。1.MySQL是关系型数据库,使用SQL进行CRUD操作。2.安装简单,需配置root用户密码。3.使用INSERT、UPDATE、DELETE、SELECT进行数据操作。4.复杂查询可使用ORDERBY、WHERE和JOIN。5.调试需检查语法,使用EXPLAIN分析查询。6.优化建议包括使用索引、选择合适数据类型和良好编程习惯。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

WebStorm Mac版
好用的JavaScript开发工具