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 5.7之中文全文检索

    深度解析MySQL 5.7之中文全文检索

    InnoDB默认的全文索引parser非常合适于Latin,因为Latin是通过空格来分词的。但对于像中文,日文和韩文来说,没有这样的分隔符。一个词可以由多个字来组成,所以我们需要用不同的方式来处理。在MySQL 5.7.6中我们能使用一个新的全文索引插件来处理它们:n-gram parser。
    2016-12-12
  • mysql ERROR 1044 (42000): Access denied for user ''''@''localhost'' to database

    mysql ERROR 1044 (42000): Access denied for user ''''@''loca

    这篇文章主要介绍了mysql下提示ERROR 1044 (42000): Access denied for user ''@'localhost' to database,需要的朋友可以参考下
    2015-09-09
  • MySQL数据库运维之数据恢复的方法

    MySQL数据库运维之数据恢复的方法

    本篇文章主要介绍了MySQL数据库运维之数据恢复的方法,此处总结一下恢复方案,并结合数据库的二进制日志做下数据恢复的示范。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • SQL结果如何根据某个字段取最新时间去重

    SQL结果如何根据某个字段取最新时间去重

    在日常的项目开发当中,经常会遇到获取同一属性相同的记录,如何获取记录时间最新的那一条,下面这篇文章主要给大家介绍了关于SQL结果如何根据某个字段取最新时间去重的相关资料,需要的朋友可以参考下
    2023-06-06
  • MySQL Threads_running飙升与慢查询的相关问题解决

    MySQL Threads_running飙升与慢查询的相关问题解决

    这篇文章主要介绍了MySQL Threads_running飙升与慢查询的问题解决,帮助大家更好的理解和学习使用MySQL数据库,感兴趣的朋友可以了解下
    2021-05-05
  • mysql密码中有特殊字符&在命令行下登录的操作

    mysql密码中有特殊字符&在命令行下登录的操作

    这篇文章主要介绍了mysql密码中有特殊字符&在命令行下登录的操作,具有很好的参考价值希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • Win10 MySQL如何解决secure_file_priv在my.ini无法设置问题

    Win10 MySQL如何解决secure_file_priv在my.ini无法设置问题

    这篇文章主要介绍了Win10 MySQL如何解决secure_file_priv在my.ini无法设置问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • mybatis mysql delete in操作只能删除第一条数据的方法

    mybatis mysql delete in操作只能删除第一条数据的方法

    这篇文章主要介绍了mybatis mysql delete in操作只能删除第一条数据的问题及解决方法,需要的朋友可以参考下
    2018-09-09
  • MySQL删除有外键约束的表数据方法介绍

    MySQL删除有外键约束的表数据方法介绍

    这篇文章主要介绍了MySQL删除有外键约束的表数据方法介绍,还是非常不错的,这里给大家分享下,需要的朋友可以参考。
    2017-10-10
  • MySQL中的JSON_CONTAINS函数举例详解

    MySQL中的JSON_CONTAINS函数举例详解

    这篇文章主要给大家介绍了关于MySQL中JSON_CONTAINS函数举例详解的相关资料,MySQL JSON_CONTAINS函数可用于判断JSON数组中是否包含某个元素,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12

最新评论