MySQL8.0的错误日志

使用MySQL的时候,会经常涉及几个日志,例如二进制日志、慢查询日志、REDO日志、UNDO日志、错误日志以及通用日志。每种日志都有自己的用处和用法,建议日常使用中根据需要,选择开启不同的日志。

今天在这里主要介绍一下MySQL8.0里对错误日志的改进。MySQL8.0的错误日志可以理解为一个全新的日志,在这个版本里,接受了来自社区的广泛批评意见,在这些意见和建议的基础上生成了新的日志。

下面这些是来自社区的意见:

  • 默认情况下内容过于冗长
  • 遗漏了有用的信息
  • 难以过滤某些信息
  • 没有标识错误信息的子系统源
  • 没有错误代码,解析消息需要识别错误
  • 引导消息可能会丢失
  • 固定格式

针对这些意见,MySQL做了如下改变:

  • 采用组件架构,通过不同的组件执行日志的写入和过滤功能
  • 写入错误日志的全部信息都具有唯一的错误代码从10000开始
  • 增加了一个新的消息分类《system》用于在错误日志中始终可见的非错误但服务器状态更改事件的消息
  • 增加了额外的附加信息,例如关机时的版本信息,谁发起的关机等等
  • 两种过滤方式,Internal和Dragnet
  • 三种写入形式,经典、JSON和syseventlog

这些新功能完全满足了广大用户所提出的要求,接下来将会具体说明相关功能。

组件架构:包括写入和过滤两大类,从可用组件中选取适用部分激活使用。

过滤方式:包括Internal和Dragnet。Internal方式通变量来控制日志的内容和详细级别。两个变量为log_error_verbosity和

log-error-suppression-list。log_error_verbosity的值为1,2,3分别对应

ERROR, WARNING, INFORMATION的组合,默认为2,既ERROR+WARNING。

log-error-suppression-list对应各种错误代码,不希望在日志里面显示的相关信息,可以通过设定相关的错误代码来控制。例如:“-SET PERSIST log_error_suppression_list=‘ER_PARSER_TRACE, MY-010001,10002’”

Dragnet方式则更加灵活,类似于编写脚本,用户可以根据需要自行编写规则,每条规则是一个IF语句以"."结束,可以包含多条规则。例如:“SET GLOBAL dragnet.log_error_filter_rules = 'IF prio>=INFORMATION THEN drop. IF EXISTS source_line THEN unset source_line.';”

详细的语法内容可以参照在线手册:“https://dev.mysql.com/doc/refman/8.0/en/error-log-rule-based-filtering.html”

写入方式和输出格式:

默认的方式:将日志写入文件,输出格式为:timestamp thread_id [priority] [err_code] [subsystem] message

JSON方式:需要安装组件“INSTALL COMPONENT 'file://component_log_sink_json';”并在服务中添加“SET GLOBAL log_error_services = 'log_filter_internal; log_sink_json';”输出的格式为:

{
  "prio": 3,
  "err_code": 10051,
  "source_line": 533,
  "source_file": "event_scheduler.cc",
  "function": "run",
  "msg": "Event Scheduler: scheduler thread started with id 5",
  "time": "2020-03-19T12:30:20.297184Z",
  "ts": 1584621317167,
  "thread": 5,
  "err_symbol": "ER_SCHEDULER_STARTED",
  "SQL_state": "HY000",
  "subsystem": "Server",
  "buffered": 1584621020297184,
  "label": "Note"
}

系统日志方式:允许mysqld将日志写入Windows的event log或类UNIX系统的syslog。同样需要安装组件和加载服务:INSTALL COMPONENT 'file://component_log_sink_syseventlog';SET GLOBAL log_error_services = 'log_filter_internal; log_sink_syseventlog';输出的格式与对应的系统日志格式相同。

关于错误日志的介绍内容到此为止,更为详细的信息请访问官网“https://dev.mysql.com/doc/refman/8.0/en/error-log.html”,希望新的日志能够给您带来帮助。

本文分享自微信公众号 - MySQL解决方案工程师(mysqlse),作者:徐轶韬

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-07-02

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • MySQL的一般查询日志

    MySQL有很多种日志,这一篇文章里主要介绍一般查询日志。General Query Log,一般查询日志是用来记录MySQL服务器做了哪些事情,当客户端连接至...

    MySQLSE
  • MySQL的审计功能

    安全高效的使用数据库,在现在的IT环境里显得尤为重要,审计功能可以对数据库的操作进行评估,以满足安全生产和法律法规的要求。MySQL的企业版里,提供了一项审计功...

    MySQLSE
  • MySQL 8.0.21复制功能强化

    MySQL 8.0.21版本具有一些有趣的复制功能。在这里我给您一个简短的摘要,更为详细的更改日志可以从官网获得。

    MySQLSE
  • Nginx 错误日志配置 原

    语法:error_log  file  level ;   # error_log 是关键字,file 是保存错误日志的文件路径,level 是错误日志级别

    拓荒者
  • [日常] nginx的错误日志error_log设置

    nginx error_log设置 1.error_log syslog:server=192.168.1.1 [级别] //直接发送给远程syslog日志集中...

    陶士涵
  • 后端实践:Nginx日志配置(超详细)

    作者 | antwang 链接 | juejin.im/post/5aa09bb3f265da238f121b6c

    Rookie
  • 使用Eclipse连接SAP Netweaver系统遇到的错误消息和解决办法

    error occurred when trying to upload ui5 project to ABAP repository in win10 在按...

    Jerry Wang
  • DartVM服务器开发(第五天)--日志工具

    上面代码的level就是下面onRecord监听能覆盖的范围,我们传入ALL,就是全部的日志输出都监听,LogRecord是一个日志记录类,里面包换的日志的相关...

    rhyme_lph
  • 开启MYSQL慢查询日志,监控优化SQL效率

    输入命令【show variables like 'slow_query_log'】,页面会显示是否开启了慢查询日志,slow_query_log =ON,代表...

    用户6367961
  • 【学习】通过简单的Excel分析网站日志数据

    昨天在一个QQ交流群里看到有一个新手发问,如何去简单的分析网站日志,清楚知道网站的一个数据抓取情况,哪些目录抓取较好,有哪些IP段蜘蛛抓取等。 ...

    小莹莹

扫码关注云+社区

领取腾讯云代金券