mysql binlog日志查询不出语句问题及解决

 更新时间:2024年01月18日 14:32:46   作者:DBA界的小学生  
这篇文章主要介绍了mysql binlog日志查询不出语句问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql binlog日志查询不出语句

当bin-log的模式设置为 row时

不仅日志长得快 并且查看执行的sql时 也稍微麻烦一点:

1.干扰语句多

2.生成sql的编码需要解码

binlog_format=row

直接mysqlbinlog出来的 文件

执行sql部分的sql显示为base64编码格式

固生成sql记录的时候 不能用常规的办法去生成 需要加上相应的参数才能显示出sql语句

--base64-output=decode-rows -v

例如:

/opt/MySQL/bin/mysqlbinlog --base64-output=decode-rows -v --start-date='2014-09-16 14:00:00' --stop-date='2014-09-16 14:20:00' /opt/mysql/log/mysql-bin.000017 >/opt/mysql_bak/mysqlbinlogsql_restore_2014091614.sql

mysql的binlog日志

查看和配置binlog

1、log_bin 是否开启binlog,指定日志文件路径

2、log_bin_basename 和 log_bin_index 日志文件基础名和索引名(*好像不能用来设置只是展示作用,我设置时时会报错无法启动服务)

3、binlog_format 日志格式

4、binlog_error_action 设置当binlog日志数据一致性遭到破坏或者复制操作停止时,服务器要做什么操作。有两个选项ABORT_SERVER 服务关闭(默认值), IGNORE_ERROR 忽略错误。

操作binglog日志的常用命令

1、show master logs; 或者 show binary logs; 查看所有binlog日志列表。

2、show master status; 查看master状态。

  • File 最新的一个binlog日志的编号名称
  • Position 最后一个操作事件pos结束点的值

3、flush logs; 刷新log日志文件,从当前时间开始产生一个新编号的binlog日志文件。

******每当mysqld服务重启时,会自动执行此命令,刷新binlog日志;在mysqldump备份数据时加 -F 选项也会刷新binlog日志;

4、reset master; 清空所有binlog日志

使用mysql自带的mysqlbinlog命令和grep命令 查看binlog

1、mysqlbinlog   【参数 】 【binlog文件】  

  • -d, --database=name        仅显示指定数据库的转储内容。
  • -o, --offset=#            跳过前N行的日志条目。
  • -r, --result-file=name        将输入的文本格式的文件转储到指定的文件。
  • -s, --short-form        使用简单格式。
  • --set-charset=name              在转储文件的开头增加'SET NAMES character_set'语句。
  • --start-datetime=name        日志的起始时间。
  • --stop-datetime=name        日志的截止时间。
  • -j, --start-position=#        日志的起始位置。
  • --stop-position=#        日志的截止位置。
  • --base64-outputbinlog        输出语句的base64解码 

分为三类:

默认是值auto ,仅打印base64编码的需要的信息,如row-based 事件和事件的描述信息。

  • never 仅适用于不是row-based的事件
  • decode-rows 配合--verbose选项一起使用解码行事件到带注释的伪SQL语句
  • -v,--verbose :显示statement模式带来的sql语句

***解析mixed格式binlog需要使用 --base64-output=DECODE-ROWS --verbose或--base64-output=DECODE-ROWS -v 来解析

2、grep '【关键字】'  【参数】

grep是一个强大的文本搜索工具命令,用于查找文件中符合指定格式的字符串,支持正则表达式。

grep命令常用参数说明

  • -A 除了显示符合条件的那一行之外,并显示该列之后的指定行的内容内容。
  • -B 除了显示符合条件的那一行之外,并显示该列之前的指定行的内容内容。
  • -c 计算符合结果的行数。
  • -i 忽略字符大小写
  • -v 反向查找
  • -e 按指定字符串查找
  • -E 按指定字符串指定的正则查找
  • -n 在显示符合条件的那一行前,标识出该行的行数标号。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • mysql下修改engine引擎的方法

    mysql下修改engine引擎的方法

    修改mysql的引擎为INNODB,可以使用外键,事务等功能,性能高。
    2011-08-08
  • MySQL慢查询之开启慢查询

    MySQL慢查询之开启慢查询

    开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。下面这篇文章主要介绍了关于MySQL开启慢查询的相关资料,需要的朋友可以参考下。
    2017-03-03
  • MySQL的root密码忘记怎么办 修改root密码的方式

    MySQL的root密码忘记怎么办 修改root密码的方式

    MySQL数据库的root密码忘记,怎么办?修改root密码的三种方式你知道吗?下面就为大家提供详细的解决方案,需要的朋友可以参考下
    2016-04-04
  • mysql unix准换时间格式查找指定日期数据代码

    mysql unix准换时间格式查找指定日期数据代码

    这篇文章主要介绍了mysql unix准换时间格式查找指定日期数据,需要的朋友可以参考下
    2014-03-03
  • 内网ssh/mysql登录缓慢的解决方法

    内网ssh/mysql登录缓慢的解决方法

    本文介绍了“内网ssh/mysql登录缓慢的解决方法”,需要的朋友可以参考一下
    2013-03-03
  • MySQL按常规排序、自定义排序和按中文拼音字母排序的方法

    MySQL按常规排序、自定义排序和按中文拼音字母排序的方法

    MySQL常规排序、自定义排序和按中文拼音字母排序,在实际的SQL编写时,我们有时候需要对条件集合进行排序。下面给出3种比较常用的排序方式,一起看看吧
    2017-04-04
  • mysql定时删除过期数据记录的简单方法

    mysql定时删除过期数据记录的简单方法

    今天小编就为大家分享一篇mysql定时删除过期数据记录的简单方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08
  • 关于MySQL中的 like操作符详情

    关于MySQL中的 like操作符详情

    这篇文章主要介绍了MySQL之like操作符,当对未知或者说知道某一部分的值进行过滤时,可以使用like操作符;like操作符用于模糊匹配。下面我们一起进入文章看看文章是我详细内容
    2021-11-11
  • MySQL报1045错误的几种可能场景

    MySQL报1045错误的几种可能场景

    mysql数据库中常常会遇见1045错误,本文主要介绍了MySQL报1045错误的几种可能场景,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • MySQL数据库中删除重复记录简单步骤

    MySQL数据库中删除重复记录简单步骤

    这篇文章主要给大家介绍了关于MySQL数据库中删除重复记录的相关资料,在使用数据库时,出现重复数据是常有的情况,但有些情况是允许数据重复的,而有些情况是不允许的,当出现不允许的情况,我们就需要对重复数据进行删除处理,需要的朋友可以参考下
    2023-08-08

最新评论