我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql二进制日志的使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql二进制日志的使用

mysql二进制日志也就是一些mysql命令操作的记录

删除二进制日志信息:

二进制日志会记录大量的信息(其中包含一些无用的信息)。如果很长时间不清理二进制日志,将会浪费很多的磁盘空间。但是,删除之后可能导致数据库崩溃时无法进行恢复,所以若要删除二进制日志首先将其和数据库备份一份,其中也只能删除备份前的二进制日志,新产生的日志信息不可删(可以做即时点还原)。也不可在关闭mysql服务器之后直接删除因为这样可能会给数据库带来错误的。若非要删除二进制日志需要做如下操作:导出备份数据库和二进制日志文件进行压缩归档存储。删除二进制文件的方法如下:

1、使用RESET MASTER语句可以删除所有的二进制日志重新记录

mysql> reset master;

mysql> show binary logs;

解析:首先不建议在生产环境下使用此操作;删除所有的二进制日志后,Mysql将会重新创建新的二进制日志。新二进制日志的编号从000001开始。

2、根据文件或时间点来删除二进制日志:

语法形式:

mysql> PURGE { BINARY | MASTER } LOGS {TO 'log_name' | BEFORE datetime_expr }

其中TO'log_name'表示把这个文件之前的其他文件都删除掉,也可使用BEFORE datetime_expr指定把哪个时间之前的二进制文件删除了。

mysql> PURGE BINARY LOGS TO 'mysql-bin.000007';  #把mysql-bin.000007文件之前的其他文件都删除掉(000001--000006)

mysql> PURGEBINARY LOGS BEFORE '2013-10-19 10:26:36'; #使用时间来删除二进制日志

★注意:my.cnf配置开启二进制日志功能默认记录所有数据库,如果指定数据库做二进制日志记录则添加

log-bin = mysql-bin

binlog-do-db = happy

binlog-do-db = iwker_global

##二进制开启状态:

mysql> show global variables like "%log_bin%";

##使用show master status命令可以查看当前启用二进制日志记录的数据库

mysql> show master status;

+------------------+----------+-----------------------------------------------+------------------+-------------------+

| File             | Position | Binlog_Do_DB                                  | Binlog_Ignore_DB | Executed_Gtid_Set |

+------------------+----------+-----------------------------------------------+------------------+-------------------+

| mysql-bin.000002 |      120 | iwker_global,iwker_inside,iwker_ucenter |                  |                   |

+------------------+----------+-----------------------------------------------+------------------+-------------------+

##查看MySQL Server上的二进制日志

mysql> show binary logs;

★★★使用mysqlbinlog工具进行恢复

步骤:

1、分析定位关键的位置或者时间点

2、导入全库备份的文件

3、注释掉误操作的命令或者避开误操作的时间点进行导入

//二进制日志转换成可读的SQL文件

mysqlbinlog mysql-bin.000001 > mysql.sql    

//或者只导出某个指定数据库的二进制日志

mysqlbinlog -d happy mysql-bin.000001 > happy_bin.sql

a.查询二进制日志文件含有drop操作的记录

mysqlbinlog binlog.0000003 |less    //输出包括在binlog.000003中包含的所有语句,以及其它信息例如每个语句花费的时间、客户发出的线程ID、发出线程时的时间戳等等。

mysqlbinlog mysql-bin.000002 |grep -i -C 2 "drop table" -c

b.根据时间来还原 --start-datetime,--stop-datetime

mysqlbinlog --start-datetime="2010-09-29 18:00:00" --stop-datetime="2010-09-29 23:00:00" /var/lib/mysql/mysql-bin.000002 |mysql -u root -p

mysqlbinlog --stop-datetime='2016-07-21 14:40:10' /var/log/mysql-bin.000001 | mysql -uroot -p

c.根据数据库名来进行还原

mysqlbinlog -d iwker_inside  /var/lib/mysql/mysql-bin.000002

d.基于位置恢复

mysqlbinlog --start-position=370 --stop-position=440  /var/lib/mysql/mysql-bin.000002 |mysql -u root -p


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql二进制日志的使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL二进制日志作用

MySQL的二进制日志(Binary Log)记录了数据库的所有更改信息,主要包括以下作用:数据恢复:在数据丢失或损坏的情况下,可以利用二进制日志进行数据恢复。通过回放(replay)二进制日志,可以重新执行在日志记录期间发生的所有数据库操
MySQL二进制日志作用
2024-10-20

Linux MySQL的二进制日志管理

MySQL的二进制日志(Binary Log)是一种记录数据库更改的日志文件,可以用于数据恢复、复制和故障恢复等操作。在Linux系统中,管理MySQL的二进制日志可以通过以下几种方式进行:配置MySQL的二进制日志参数:在MySQL配置文
Linux MySQL的二进制日志管理
2024-08-16

怎么开启mysql二进制日志

要开启 MySQL 二进制日志功能,需要按照以下步骤操作:编辑 MySQL 的配置文件 my.cnf,找到并打开以下配置选项,如果没有则手动添加:log_bin = /var/log/mysql/mysql-bin.log这里的 log_b
怎么开启mysql二进制日志
2024-04-09

MySQL二进制日志分析技巧

MySQL二进制日志记录了数据库的所有更改,包括数据变更、表结构变更、SQL语句等。分析MySQL二进制日志可以帮助我们追踪数据变更历史、审计数据库操作、恢复数据等。以下是一些分析MySQL二进制日志的技巧:使用工具:使用专门的工具如mys
MySQL二进制日志分析技巧
2024-10-20

编程热搜

目录