广告
返回顶部
首页 > 资讯 > 数据库 >mysql二进制日志的使用
  • 334
分享到

mysql二进制日志的使用

2024-04-02 19:04:59 334人浏览 安东尼
摘要

Mysql二进制日志也就是一些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


您可能感兴趣的文档:

--结束END--

本文标题: mysql二进制日志的使用

本文链接: https://www.lsjlt.com/news/44788.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • mysql二进制日志的使用
    mysql二进制日志也就是一些mysql命令操作的记录删除二进制日志信息:二进制日志会记录大量的信息(其中包含一些无用的信息)。如果很长时间不清理二进制日志,将会浪费很多的磁盘空间。但是,删除之后可能导致数...
    99+
    2022-10-18
  • MySQL日志-二进制日志(Binlog)
    MySQL有下面几个不同的日志文件,可以帮助你找出mysqld内部发生的事情: 日志文件 ...
    99+
    2022-10-18
  • MySQL二进制日志的使用方法
    这篇文章给大家分享的是MySQL二进制日志的使用方法,使用二进制日志可以实现异地容灾备份、读写分离、数据恢复等功能,通过这篇文章的总结,希望你能学会使用MySQL二进制日志。开启bin-log日志Mysql...
    99+
    2022-10-18
  • 如何使用MySQL二进制日志
    下文主要给大家带来如何使用MySQL二进制日志,希望这些内容能够带给大家实际用处,这也是我编辑如何使用MySQL二进制日志这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。下载Navicat for ...
    99+
    2022-10-18
  • 开启MySQL二进制日志(binlog)
    前言 binlog即二进制日志 Binary Log,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日志是事务安全型的。一般来说...
    99+
    2023-09-22
    mysql 数据库
  • Mysql清理二进制日志的技巧
    1:二进制日志二进制日志记录了所有的DDL(数据定义语言)语句和DML(数据操作语言)语句,但是不记录包括数据查询的语句。语句以“事件”的形式保存,它描述了数据的更改过程,此日志对于灾难时的数据恢复起着极其...
    99+
    2022-10-18
  • 【MySQL】备份二进制日志--Binlog Server
    mysqlbinlog会伪装成一个slave,连接主库请求指定的binlog file, 主库接收到这个请求之后创建一个binlog dump线程推送binlog给mysqlbinlog server。 ...
    99+
    2022-10-18
  • 怎么管理mysql二进制日志
    本篇内容主要讲解“怎么管理mysql二进制日志”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么管理mysql二进制日志”吧! 使用...
    99+
    2022-10-19
  • 如何删除mysql二进制日志
    今天小编给大家分享一下如何删除mysql二进制日志的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一...
    99+
    2022-10-19
  • mysql如何删除二进制日志
    本篇内容主要讲解“mysql如何删除二进制日志”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql如何删除二进制日志”吧! 3种...
    99+
    2022-10-19
  • mysql如何关闭二进制日志
    这篇文章主要介绍“mysql如何关闭二进制日志”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql如何关闭二进制日志”文章能帮助大家解决问题。 ...
    99+
    2022-10-19
  • 重做日志与二进制日志
    MySQL 中有六种日志文件, 分别是:重做日志( redo log )、回滚日志( undo log )、二进制日志( binlog )、错误日志( er...
    99+
    2022-10-18
  • MYSQL中的二进制日志是怎样的
    这期内容当中小编将会给大家带来有关MYSQL中的二进制日志是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。数据库开启二进制日志:1.修改/etc/my.cnf[ro...
    99+
    2022-10-18
  • Mysql数据库二进制日志的管理
    如果配置了log_bin参数,则需要配置expire_logs_days参数指定二进制日志保留时间,不然磁盘空间早晚会被日志占满的。如果之前没有配置,则配置步骤如下:   1、查...
    99+
    2022-10-18
  • MySQL二进制日志的格式有哪些
    这篇文章主要介绍“MySQL二进制日志的格式有哪些”,在日常操作中,相信很多人在MySQL二进制日志的格式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL二进制...
    99+
    2022-10-18
  • MySQL二进制日志(binlog)解析工具
     一、工具介绍    - binlog2parser.py是一款MySQL二进制日志(binlog)解析工具,支持mysql5.6/5.7    - binlog2parser.json文件配置日志文件对应的数据库连接信息,用于解析列名 二...
    99+
    2023-09-04
    mysql 数据库 python
  • MYSQL中怎么管理二进制日志
    这期内容当中小编将会给大家带来有关MYSQL中怎么管理二进制日志,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。MYSQL二进制日志管理脚本 脚本原理是每小时对进...
    99+
    2022-10-18
  • mysql中怎么删除二进制日志
    本篇文章给大家分享的是有关mysql中怎么删除二进制日志,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、删除mysql二进制日志 ...
    99+
    2022-10-18
  • MySQL怎么使用二进制日志恢复数据库
    本篇内容主要讲解“MySQL怎么使用二进制日志恢复数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL怎么使用二进制日志恢复数据库”吧!一、二进制日志...
    99+
    2022-10-18
  • mysql中如何查看binlog二进制日志
    这篇文章给大家分享的是有关mysql中如何查看binlog二进制日志的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。例如,在创建新表或更新现有表上的数据时,这些事件将存储在mysq...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作