前言:今天早上在写博客时,思索再三,没有更好的头绪,就想起了以前在操作mysql的时候,经常要用的一些命令,下面就来简单介绍一下
备份数据:
C:\Users\xxxx>mysqldump -uxxx -pxxx backup > backup.sql C:\Users\xxxx>
mysqldump :mysql用于存储数据库的应用程序,会产生一个sql文件,如上文的backup.sql,其中包含了数据库的create、insert into等语句。
随后我们使用dir命令查看一下C:\Users\xxxx>目录的文件列表,可以看到
2014/08/23 10:15 1,271 backup.sql
恢复数据:
mysql> use backup; Database changed mysql> source C:\Users\xxxx\backup.sql Query OK, 0 rows affected (0.00 sec) Query OK, 0 rows affected (0.03 sec)
使用mysql命令进入到mysql命令行,使用use backup切换数据库,然后使用source命令进行数据的恢复。
以上source命令在处理mysql的大量数据恢复时,速度还是比较可观的。
但是我们在真实的项目当中,经常需要用到二进制日志,那么下面我们来做一个二进制的日志备份操作
首先:我们查看一下mysql二进制日志是否开启
mysql> show variables like 'log_bin'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | log_bin | OFF | +---------------+-------+ 1 row in set (0.14 sec)
第二步:我们开启二进制日志(在Windows的mysql安装目录中的my.ini文件中增加以下内容,确保你的f盘有mysqlbin目录)
# add log-bin log-bin=f:/mysqlbin/binlog.log # set the database for test binlog-do-db=backup
第三步:我们重启一下mysql
C:\Users\xxxx>net stop mysql MySQL 服务正在停止. MySQL 服务已成功停止。 C:\Users\xxxx>net start mysql MySQL 服务正在启动 . MySQL 服务已经启动成功。
第四步:再次查看log_bin是否开启
mysql> show variables like 'log_bin'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | log_bin | ON | +---------------+-------+ 1 row in set (0.00 sec)
第五步:对backup数据库进行一下操作,假如已经存在
mysql> show columns from binlog; +-------+---------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+---------+------+-----+---------+-------+ | id | int(11) | YES | | NULL | | +-------+---------+------+-----+---------+-------+ 1 row in set (0.08 sec) mysql>
我们插入一条数据
mysql> insert into binlog values (2); Query OK, 1 row affected (0.01 sec) mysql> select * from binlog; +------+ | id | +------+ | 1 | | 2 | +------+ 2 rows in set (0.00 sec) mysql>
第六步:我们查看一下二进制日志目录
F:\mysqlbin>dir 驱动器 F 中的卷是 F: 卷的序列号是 000C-A0EB F:\mysqlbin 的目录 2014/08/23 11:02 <DIR> . 2014/08/23 11:02 <DIR> .. 2014/08/23 11:02 126 binlog.000001 2014/08/23 11:02 107 binlog.000002 2014/08/23 11:02 52 binlog.index 3 个文件 285 字节 2 个目录 117,389,742,080 可用字节
第七步:我们再使用mysqlbinlog查看一下,内容比较多,上下使用了...空过,可以看到"insert into binlog values (2)"为我们刚刚操作的内容
F:\mysqlbin>mysqlbinlog binlog.000002
...
use backup/*!*/;
SET TIMESTAMP=1408763281/*!*/;
insert into binlog values (2)
/*!*/;
# at 271
#140823 11:08:01 server id 1 end_log_pos 298 Xid = 9
...
那么我们再次回去标题讲的二进制日志恢复和备份,备份就如前文所讲,那么就再来说说二进制的恢复
第一种:使用source命令,二进制日志是不能直接通过source命令来恢复,那么我们需要按照以下步骤来进行
第一步:先将二进制日志转换成普通sql文件
F:\mysqlbin>mysqlbinlog -uxxx -pxxx binlog.000001 > binlog1.sql F:\mysqlbin>mysqlbinlog -uxxx -pxxx binlog.000002 > binlog2.sql F:\mysqlbin>dir 驱动器 F 中的卷是 F: 卷的序列号是 000C-A0EB F:\mysqlbin 的目录 2014/08/23 11:22 <DIR> . 2014/08/23 11:22 <DIR> .. 2014/08/23 11:02 126 binlog.000001 2014/08/23 11:08 298 binlog.000002 2014/08/23 11:02 52 binlog.index 2014/08/23 11:22 644 binlog1.sql 2014/08/23 11:22 1,569 binlog2.sql 5 个文件 2,689 字节 2 个目录 117,389,737,984 可用字节
第二步:新建一个sql文件,里面输入以下内容
source F:\mysqlbin\binlog1.sql source F:\mysqlbin\binlog2.sql
第三步:导入以上的sql文件
mysql> source C:\Users\xxx\backup.sql Query OK, 0 rows affected (0.00 sec)
第二种方法,使用mysqlbinlog
F:\mysqlbin>mysqlbinlog binlog.000001 | mysql -uroot -proot F:\mysqlbin>mysqlbinlog binlog.000002 | mysql -uroot -proot
最后:这些简单的,常用的命令,以及使用方式都是非常值得总结的。
相关推荐
MySQL的二进制日志(Binary Log)是数据库系统中用于记录所有更改数据的SQL语句的重要工具,它对于数据库的备份、恢复以及故障排查至关重要。`mysqlbinlog`是MySQL提供的一款命令行实用程序,专门用于处理和解析二...
MySQL的二进制日志(Binary Log)是数据库系统中用于记录所有更改数据的SQL语句的一种机制,它对于数据恢复、主从复制等场景至关重要。重做二进制日志,即根据二进制日志中的内容重新执行SQL操作,以达到数据恢复的...
- **二进制日志(Binlog)备份**:MySQL的二进制日志记录了所有更改数据库的操作,可用于数据恢复和点恢复。 - **直接拷贝数据文件**:对于MyISAM表,可以直接复制表数据文件;而对于InnoDB表,可以通过拷贝数据文件...
需要创建如 `/var/lib/mysql` 和 `/var/log/mysql` 这样的目录,以存储数据文件和日志,并用`chown`和`chmod`命令调整权限,确保MySQL用户和组对这些目录有适当的访问权限。 8. **创建mysql的配置文件**: 在 `/...
首先,MySQL的日志系统包括错误日志、二进制日志、普通查询日志、慢查询日志和中继日志。错误日志记录了启动、关闭过程中的信息,运行中的错误,以及事件调度和从服务器启动的信息。启用错误日志可以通过设置`log_...
1、利用Mysqldump+二进制日志实现备份 2、利用LVM快照+二进制日志实现备份 3、使用Xtrabackup备份 一:实验环境介绍: 系统介绍:CentOS6.4_X64 数据库版本:mysql-5.5.33 二:基于Mysqldump命令实现备份恢复 2.1、...
首先,确定发生错误的精确时间点,然后使用`mysqlbinlog`工具结合二进制日志文件和具体时间点,生成需要的SQL语句,再导入到数据库中。 总的来说,MySQL备份是数据库管理的重要组成部分,通过合理的备份策略和自动...
日志系统包括错误日志、二进制日志(binlog)、查询日志和慢查询日志。 1. 错误日志:`jcsys4-23.err`文件记录了MySQL服务器运行过程中的错误信息,帮助管理员识别和解决问题。 2. 二进制日志:通过设置`log-bin`...
- **全量备份**:通常通过执行`mysqldump`命令生成SQL脚本或者直接导出二进制日志文件。在Java中,可以使用`Runtime.getRuntime().exec()`方法执行系统命令来调用`mysqldump`。例如,创建一个包含所有数据库的备份...
8. 数据恢复:当需要从备份恢复时,先应用备份的二进制日志,然后使用`xtrabackup --prepare`命令来准备备份数据,最后通过MySQL的`mysqladmin`或`mysqldump`工具导入数据。 9. 注意事项:备份过程中应监控系统资源...
通过设置`--master-data`选项,mysqldump还可以在备份文件中包含二进制日志位置,这样在恢复后可以确保数据一致性。 在"mysql备份恢复代码实例"中,你可能还会发现如何使用binlog进行点恢复的代码。这涉及到定位到...
这需要熟悉如何使用mysql命令行工具来导入mysqldump生成的SQL文件,以及如何处理和应用二进制日志。 总结来说,MySQL数据库备份是多方面的,涉及选择合适的备份策略、理解不同备份方法的优缺点,以及在恢复过程中的...
4. **二进制日志**: MySQL的二进制日志记录了所有改变数据库的数据更改事件,可用于增量备份和恢复。 在CentOS 8中,备份策略可能还包括系统级别的快照,例如使用LVM快照或Rsync,这样可以同时保护MySQL数据和系统...
8. 复原功能:备份的目的在于数据恢复,这款工具可能包含一键恢复功能,将备份文件轻松导入到MySQL服务器,快速恢复数据。 9. 文件压缩:备份文件通常会被压缩成ZIP或RAR格式,节省存储空间,并提高传输效率。 10....
增量备份的实现依赖于MySQL的二进制日志功能,它记录了所有改变数据库的事务。`mysqldump --incremental` 或 `--master-data` 参数可以在导出时包含二进制日志信息。 **恢复过程** 1. **直接拷贝恢复**:对于直接...
本文主要探讨了MySQL的错误日志、二进制日志(BINLOG)、数据备份和数据恢复这四个关键知识点。 首先,错误日志是MySQL在遇到任何故障时的第一参考源,它记录了服务器启动、关闭以及运行过程中的错误信息。错误日志...
首先,MySQL的免费备份工具有mysqldump、mysqlhotcopy以及SQL命令如BACKUP TABLE、SELECT INTO OUTFILE和备份二进制日志(binlog)。MyISAM表因其文件存储方式,备份相对简单,上述方法均可适用。而InnoDB表的数据和...
3. **增量备份**:在全量备份基础上,可以利用`mysqldump`配合`--master-data`选项记录二进制日志位置,实现基于时间点的增量备份。但MySQL本身并不直接支持真正意义上的增量备份,需要结合其他工具如Percona ...