MySQL 日志(一)

本篇主要介绍MySQL日志的相关内容。

目录

一、日志简介

常用日志

一般查询日志和慢查询日志的输出形式

 日志表

二、一般查询日志 

三、慢查询日志

四、错误日志


一、日志简介

常用日志

在MySQL中常用的日志主要有如下几种:

这些日志通常情况下都是关闭的,需要我们通过对应的选项来打开。但也有意外,在windows中,错误日志是默认开启的,而在Linux中,则默认开启了二进制日志和错误日志。这些日志一旦开启,会默认将记录日志信息的文件保存到MySQL的数据目录(data)中。


一般查询日志和慢查询日志的输出形式

在MySQL中我们可以通过设置--log-output这个选项来控制一般查询日志和慢查询日志的输出形式式,这个选项一共有三个value值,具体如下:

  • TABLE:将日志信息输出到对应的日志表中
  • FILE:将日志信息输出到日志文件中
  • NONE:不输出日志信息

如果没有设置value值,默认为FILE,如果指定了多个value值,则这多个value值都生效,也就是说可以既输出到表又可以输出到文件,需要注意的是NONE的优先级最高,这也就意味着只要包含NONE其它的value值都失效。


 日志表

前面我们提到了日志表,那么什么是日志表呢?日志表就是根据日志信息生成的表,其字段对应着日志信息中的各部分内容,新增一条日志就是往日志表中插入一行数据,我们可以通过日志表来查询所需要的日志信息。

通过下面的SQL语句我们能够查看日志表的建表信息

show create table 日志表名称

下面我们尝试查询一下一般查询日志的日志表的建表信息(表名为general.log) 

表中字段的具体含义将在后文介绍。

使用日志表主要有以下两点好处:

  • 可以通过SQL查询日志信息,有利于我们过滤日志内容,快速找到我们想要的日志信息
  • 客户端能够以表查询的方式来获取日志信息,不在需要登录服务器主机访问文件系统 

接下来我们详细介绍一下部分日志。

二、一般查询日志 

一般查询日志主要用来记录客户端建立连接和断开连接的相关信息,以及服务端从服务端接收的每一个SQL语句,因此如果开启了一般查询日志将会消耗大量的系统资源,因此,通常情况下,不建议开启。一般查询日志的开启与关闭可以通过 --general_log选项来开启与关闭。一般查询日志的文件名默认为host_name(当前机器的名称).log,这个文件名可以通过general_log_file来设置。

一般查询日志的文件内容如下:

在该文件中,我们可以看到服务器执行的每一条SQL以及连接的一些相关信息。

前面我们了解过,我们可以通过表查询的方式来查询一般查询日志 ,查询的内容具体如下:

通过上面的内容可以发现我们查询的具体SQL是只是一个编码,因此我们需要将其转换为可读的字符串,我们可以使用CAST函数来实现该功能,CAST的使用语法如下:

CAST(要转换的内容 AS 要转换为的类型)

此时我们可以通过CAST优化一下我们的查询语句:

SELECT event_time ,thread_id, server_id, command_type, CAST(argument AS CHAR) AS query FROM mysql.general_log;

我们再按这条语句进行查询,就能看到具体的SQL语句了 

三、慢查询日志

在MySQL中,慢查询日志主要用来记录那些执行时间和检查的行数超过一定阈值的SQL语句,时间阈值通过log-query-time来指定,行数的阈值通过min_examined_row_limit来指定。对于慢查询日志记录的SQL,我们需要进行分析和优化,分析时我们可以使用前面介绍过的MySQldumpslow客户端程序,需要注意的是获取锁的时间并不计入执行时间,只计入语句的执行时间和释放锁的时间,只有这个时间超过阈值,才会记入日志。因此,日志中语句的顺序可能与执行的顺序不同。

下面我们来看一下慢查询日志使用时的注意事项:

  • log_query_time的默认值为10,最小可设置为0
  • 慢查询日志默认为关闭,需要通过--slow_query_log来开启
  • 慢查询日志文件名默认为host_name-slow.log,该文件默认保存在MySQL的数据目录中。如果需要修改文件名,可以通过slow_query_log_file来修改
  • 默认情况下,慢查询日志不记录管理语句(管理语句包括ALTER TABLE 、ANALYZE TABLE 、 CHECK TBALE、CREATE INDEX 、DROP INDEX、OPTIMIZE TABLE和REPAIR TABLE。)如果要记录管理语句,需要设置log_slow_admin_statement为开启。
  • 默认情况下,慢查询日志不记录不使用索引的查询,如果要记录不使用索引的查询,需要通过log_queries_not_using_indexs系统变量来设置。需要注意的是,在开启记录不使用索引的查询后,将会大大增加写入日志的SQL的数量,因此我们需要通过log_throttle_queries_not_using_indexes系统变量来设置每分种写入慢查询日志的同类查询的数量,以免慢查询日志太大造成影响,该变量的默认值为0,表示无限制。

在MySQL中,主要有两种查看慢查询日志的方式,一种是通过慢查询日志文件,一种则是通过慢查询日志表。

慢查询日志文件中一条日志的内容大体如下:

 

其中Query_time表示SQL语句的执行时间,单位为秒,Lock_time表示为该语句获取锁的时间,单位为秒,Rows_sent表示服务端发送到客户端的行数,Rows_examined为服务端检查的行数。

在慢查询日志中还有还有一些额外的隐藏字段,这些字段默认关闭,如果要启用的话,可以通过系统变量--log-slow-extra。这些隐藏的字段如下:

慢查询日志还可以通过对应的表(slow_log)来查询,slow_log的建表语句如下:

表中的字段的内容与日志文件是对应的。 

四、错误日志

MySQLd的启动与关闭的次数,诊断信息,以及服务器运行期间发生的错误和警告一般记录在错误日志中,例如MySQL需要自动检查或者修复一个表,就会在错误日志中写下一条日志,错误日志默认使用UTF-8编码,并用英语来生成记录。

错误日志可以输出到控制台也可以输出到指定文件中,“控制台”表示stderr标准错误输出。

在Windows中,mysqld通过--log-error和--console来指定错误日志是输出到文件还是输出到控制台,如果指定了--consle则输出到控制台,如果指定了--log-error则输出到指定的文件。如果两者都有指定的话,那么-log-error会失效。如果没有指定-log-error,或者没有指定具体文件,那么会自动在数据目录生成一个host_name.err的日志文件。在Unix和Linux系统中,输出到文件还是输出到控制台,都由-log-error来指定,如果-log-error的值为stderr则输出到控制台,如果为一个文件名,则输出到该文件,如果-log-error没有指定值,则跟在Window中一样,在数据目录下生成一个host_name.err文件。前面中提到的指定文件都可以指定为绝对路径,表示,将错误日志输出到该位置的文件中。

在错误日志中主要包含以下几个核心字段:

  • time:时间戳,精度为微妙
  • msg:错误日志的描述
  • prio:事件优先级,包括System event-系统(0),Error event-错误(1),Warning event-警告(2)或者 Note/infomation event -通知/提示事件(3),值越小优先级越高
  • err_code:事件错误代码
  • err_symbol:以字符串形式表示的事件错误符,例如‘ER_DUP_KEY'
  • SQL_state:事件sqlstate值,与error_symbol对应,例如’ER_DUP_KEY'对应的SQLSTATE为23000
  • subsystem:事件发生的子系统。

 对于当前已经定义的错误事件的类型,我们可以通过如下SQL语句来查询

SELECT * FROM performance_schema.events_errors_summary_global_by_error WHERE SUM_ERROR_RAISED <> 0\G

我们来具体执行一下该sql 

此时我们就能知道当前发生过哪些类型的错误事件 。需要注意的是,对于Mysql对我们平常所执行的一些有语法问题的SQL的错误提示,是不会记录到错误日志中的,例如:

 当我们使用FLUSH ERROR LOGS、FLUSH LOGS 、 mysqladmin flush-logs命令来刷新错误日志时,服务器会将正在写入的任何错误日志文件关闭并重新打开。如果重新打开时,原来文件名的文件不存在了,就会重新创建一个原来文件名的错误日志文件,因此,当我们需要重命名文件用来做备份文件时,可以先将原本的文件重命名,然后在执行刷新操作,生成一个新的错误日志文件。具体可以进行如下操作(这里错误能日志的原始名为 host_name.err):

mv host_name.err  host_name.err-old #重命名文件

mysqladmin flush-logs #刷新文件

mv host_name.err-old 备份目录  #将重命名的文件移动到备份目录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1451677.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL日志(三):数据安全

先来看一个结论&#xff1a;只要redo log和binlog保证持久化到磁盘&#xff0c; 就能确保MySQL异常重启后&#xff0c; 数据可以恢复。 binlog写入逻辑 binlog的写入逻辑比较简单&#xff1a; 事务执行过程中&#xff0c; 先把日志写到binlog cache&#xff0c; 事务提交的时候…

C++11列表初始化{}

列表初始化 C11后为了能让自定义类型也能够快速被初始化新增 {} 内置类型变量 int a1 { 10 };int a2{ 11 };int a3 { 1 2 };int a4{ 1 2 }; 注意&#xff1a;列表初始化可以在{}之前使用等号&#xff0c;其效果与不使用没有什么区别。 内置类型数组 int arr1[] { 1,2,3…

【数据结构陈越版笔记】进阶实验1-3.1:两个有序序列的中位数

我这答案做的可能不对&#xff0c;如果不对&#xff0c;欢迎大家指出错误&#xff0c;思路大部分直接写在注释中了。 进阶实验1-3.1&#xff1a;两个有序序列的中位数 已知有两个等长的非降序序列S1, S2, 设计函数求S1与S2并集的中位数。有序序列 A 0 , A 1 , . . . , A n −…

使用sherpa-ncnn进行中文语音识别(ubuntu22)

获取该开源项目的渠道&#xff0c;是我在b站上&#xff0c;看到了由csukuangfj制作的一套语音识别视频。以下地址均为csukuangfj在视频中提供&#xff0c;感谢分享&#xff01; 新一代Kaldi RISC-V: VisionFive2 上的实时中英文语音识别_哔哩哔哩_bilibili 开源项目地址&…

SW参数化设计软件 慧德敏学

随着产品设计信息化进程的不断推进&#xff0c;企业运用三维CAD系统进行设计正日趋广泛&#xff0c;三维参数化设计无疑是提高设计效率的好方法之一。所谓参数化设计就是将模型中的约束信息变量化&#xff0c;使之成为可以调整的参数&#xff0c;赋以不同数值就可得到不同大小和…

CPN Tools学习——时间和队列【重要】

-Timed Color Sets 时间颜色集 -Token Stamps 令牌时间戳 -Event Clock 全局/事件/模拟时钟 -Time Delays on Transitions过渡的时间延迟 - List Color Set列表颜色集 - Queue排队 1.时间颜色集 在定时CPN模型令牌中有&#xff1a; &#xff08;1&#xff09;象征性的颜…

【面试干货】抽象类和接口的区别

【面试干货】抽象类和接口的区别 1、抽象类1.1、什么是抽象类&#xff1f;1.2、示例代码 2、接口2.1、什么是接口&#xff1f;2.2、示例代码 3、比较和总结3.1、使用场景3.2、关键区别3.3、代码示例比较 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&am…

【安卓设备】通过adb批量安装apk

1、adb链接设备 H:\tv\apk>adb connect 127.0.0.1:21503 2、批量安装apk 如果地址不一致需要将 H:\tv\apk\ 改成自己的路径地址&#xff0c;同时注意该命令只能安装文件名为英文的不支持中文名称&#xff0c;如果有需要先更改文件名称。 H:\tv\apk>for %f in (H:\tv\a…

VirtualBox、Centos7下安装docker后pull镜像问题

Docker安装篇(CentOS7安装)_docker 安装 centos7-CSDN博客 首先&#xff0c;安装docker可以根据这篇文章进行安装&#xff0c;安装完之后&#xff0c;我们就需要去通过docker拉取相关的服务镜像&#xff0c;然后安装相应的服务容器&#xff0c;比如我们通过docker来安装mysql,…

AI Agent学习系列:微信搭配Agent,让微信秒变特工

在之前的文章里介绍了如何把微信变成高考志愿填报小助手&#xff0c;我已经把这个bot发布到了公众号&#xff0c;大家可以直接在公众号消息输入框里提问即可直接使用&#xff0c;如图&#xff1a; 上面说的bot就是智能体&#xff0c;也叫Agent&#xff0c;和英文里特工是一个单…

【Vue】自学笔记(四)

上一篇&#xff1a;Vue笔记&#xff08;三&#xff09;-CSDN博客 1.VueCli自定义搭建项目 先确保安装了全局工具VueCli 如果没有&#xff0c;则先运行命令 npm i vue/cli -g 选择最后一个自定义搭建项目 选择需要自动搭建的功能 这里我需要router和css预处理器就空格勾选上&…

黄河流域web

1、UNSER的 <?php highlight_file(__FILE__); class Wel {public $fast;public $star;public function __construct(){$this->fast "free_toto";echo "what?";}public function __destruct(){$content $this->star;printf ($content);}pu…

使用ShinyCell展示你的单细胞数据

在我参与发表我的第一篇植物单细胞文章中&#xff0c;我用Shiny开发了一个简单的单细胞可视化网站&#xff0c;目前已经运行了5年了&#xff0c;有上万的访问&#xff0c;唯一的不足就是太简陋。我一直想着能不能找个一个更好的工具进行展示&#xff0c;最近发现了一个工具&…

Druid未授权访问漏洞修复

前言 安全组针对系统漏扫发现系统存在Druid未授权访问&#xff0c;会引发泄露系统敏感信息&#xff0c;漏洞链接为ip:端口/druid/index.html&#xff0c;可以清楚的查看数据库的相关连接信息&#xff0c;如下图所示&#xff1a; 漏洞修复 1、关闭Druid监控页面 在Druid的配…

34 Debian如何配置ELK群集

作者:网络傅老师 特别提示:未经作者允许,不得转载任何内容。违者必究! Debian如何配置ELK群集 《傅老师Debian知识库系列之34》——原创 ==前言== 傅老师Debian知识库特点: 1、拆解Debian实用技能; 2、所有操作在VMware虚拟机实测完成; 3、致力于最终形成Debian知识手…

【TB作品】MSP430 G2553 单片机 口袋板 日历 时钟 闹钟 万年历 电子时钟 秒表显示

文章目录 功能介绍操作方法部分流程图代码录制了一个演示视频可以下载观看 功能介绍 时间与日期显示&#xff1a; 实时显示当前时间&#xff08;小时、分钟、秒&#xff09;和日期&#xff08;年、月、日&#xff09;。 闹钟功能&#xff1a; 设置闹钟时间&#xff08;小时、分…

关于FPGA对 DDR4 (MT40A256M16)的读写控制 2

关于FPGA对 DDR4 &#xff08;MT40A256M16&#xff09;的读写控制 2 语言 &#xff1a;Verilg HDL EDA工具&#xff1a;ISE、Vivado、Quartus II 关于FPGA对 DDR4 &#xff08;MT40A256M16&#xff09;的读写控制 2一、引言二、DDR4的简介四、DDR4 SDRAM状态框图 关键词&#x…

高叶恋情曝光神秘素人男友浮出水面

高叶恋情曝光&#xff0c;神秘素人男友浮出水面&#xff01;在娱乐圈的璀璨星光中&#xff0c;总有一些低调而神秘的恋情&#xff0c;它们如同深藏的宝藏&#xff0c;等待着被发掘。昨日&#xff0c;知名娱乐记者刘大锤的一则爆料&#xff0c;犹如一颗重磅炸弹&#xff0c;炸响…

Go 1.19.4 字符串-Day 06

1. 编码表 计算机中只有数字&#xff08;0和1&#xff09;&#xff0c;如果有一个字符串&#xff08;字符串由字符组成&#xff09;要存储&#xff0c;在内存中该如何表达这个字符串&#xff1f; 那么所有的字符都必须数字化&#xff0c;也就是一个字符对应一个特定的数字&…

腾讯云对象存储不绑定自定义备案域名不给下载应该如何处理?

从2024年1月1日起&#xff0c;腾讯云对象存储&#xff08;COS&#xff09;将实施新政策&#xff1a;新创建的存储桶不再支持使用path-style域名&#xff08;即存储桶绝对路径&#xff09;。此外&#xff0c;使用默认域名访问的新存储桶将不再支持任意类型文件的预览&#xff0c…