浅谈MySQL中的六种日志


Posted in MySQL onMarch 23, 2022

(一)概述

MySQL中存在着以下几种日志:重写日志(redo log)、回滚日志(undo log)、二进制日志(bin log)、错误日志(error log)、慢查询日志(slow query log)、一般查询日志(general log)。

MySQL中的数据变化会体现在上面这些日志中,比如事务操作会体现在redo log、undo log以及bin log中,数据的增删改查会体现在 binlog 中。本章是对MySQL日志文件的概念及基本使用介绍,不涉及底层内容。针对开发人员而言,这几种日志中最有可能使用到的是慢查询日志。

(二)redo log

redo log是一种基于磁盘的数据结构,用来在MySQL宕机情况下将不完整的事务执行数据纠正,redo日志记录事务执行后的状态。

当事务开始后,redo log就开始产生,并且随着事务的执行不断写入redo log file中。redo log file中记录了xxx页做了xx修改的信息,我们都知道数据库的更新操作会在内存中先执行,最后刷入磁盘。

redo log就是为了恢复更新了内存但是由于宕机等原因没有刷入磁盘中的那部分数据。

(三)undo log

undo log主要用来回滚到某一个版本,是一种逻辑日志。undo log记录的是修改之前的数据,比如:当delete一条记录时,undolog中会记录一条对应的insert记录,从而保证能恢复到数据修改之前。在执行事务回滚的时候,就可以通过undo log中的记录内容并以此进行回滚。

undo log还可以提供多版本并发控制下的读取(MVCC)。

(四)bin log

MySQL的bin log日志是用来记录MySQL中增删改时的记录日志。简单来讲,就是当你的一条sql操作对数据库中的内容进行了更新,就会增加一条bin log日志。查询操作不会记录到bin log中。bin log最大的用处就是进行主从复制,以及数据库的恢复。

通过下面的命令可以查看是否开启binlog日志

show VARIABLES like '%log_bin%'

开启binlog的方式如下:

log-bin=mysql-bin
server-id=1
binlog_format=ROW

其中log-bin指定日志文件的名称,默认会放到数据库目录下,可通过以下命令查看

show VARIABLES like '%datadir%'

(五)error log

error log主要记录MySQL在启动、关闭或者运行过程中的错误信息,在MySQL的配置文件my.cnf中,可以通过log-error=/var/log/mysqld.log 执行mysql错误日志的位置。

通过MySQL的命令

show variables like "%log_error%";

也可以获取到错误日志的位置。

(六)slow query log

慢查询日志用来记录执行时间超过指定阈值的SQL语句,慢查询日志往往用于优化生产环境的SQL语句。可以通过以下语句查看慢查询日志是否开启以及日志的位置:

show variables like "%slow_query%";

慢查询日志的常用配置参数如下:

slow_query_log=1  #是否开启慢查询日志,0关闭,1开启
slow_query_log_file=/usr/local/mysql/mysql-8.0.20/data/slow-log.log  #慢查询日志地址(5.6及以上版本)
long_query_time=1 #慢查询日志阈值,指超过阈值时间的SQL会被记录
log_queries_not_using_indexes  #表示未走索引的SQL也会被记录

分析慢查询日志一般会用专门的日志分析工具。找出慢SQL后可以通过explain关键字进行SQL分析,找出慢的原因。

(七)general log

general log 记录了客户端连接信息以及执行的SQL语句信息,通过MySQL的命令

show variables like '%general_log%';

可以查看general log是否开启以及日志的位置。

浅谈MySQL中的六种日志

general log 可通过配置文件启动,配置参数如下:

general_log = on
general_log_file = /usr/local/mysql/mysql-8.0.20/data/hecs-78422.log

普通查询日志会记录增删改查的信息,因此一般是关闭的。

到此这篇关于浅谈MySQL中的六种日志的文章就介绍到这了,更多相关MySQL 日志内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
解读MySQL的客户端和服务端协议
May 10 MySQL
Mysql Online DDL的使用详解
May 20 MySQL
MySQL 使用事件(Events)完成计划任务
May 24 MySQL
MySQL下使用Inplace和Online方式创建索引的教程
May 26 MySQL
Mysql8.0递归查询的简单用法示例
Aug 04 MySQL
Mysql关于数据库是否应该使用外键约束详解说明
Oct 24 MySQL
mysql分表之后如何平滑上线详解
Nov 01 MySQL
一篇文章看懂MySQL主从复制与读写分离
Nov 07 MySQL
一条慢SQL语句引发的改造之路
Mar 16 MySQL
MySQL数据库查询进阶之多表查询详解
Apr 08 MySQL
sql查询语句之平均分、最高最低分及排序语句
May 30 MySQL
MySQL串行化隔离级别(间隙锁实现)
Jun 16 MySQL
WINDOWS 64位 下安装配置mysql8.0.25最详细的教程
实战 快速定位MySQL的慢SQL
关于MySQL临时表为什么可以重名的问题
将MySQL的表数据全量导入clichhouse库中
Mar 21 #MySQL
MySQL分区表管理命令汇总
Mar 21 #MySQL
Linux系统下MySQL配置主从分离的步骤
如何创建一个创建MySQL数据库中的datetime类型
Mar 21 #MySQL
You might like
PHP异常Parse error: syntax error, unexpected T_VAR错误解决方法
2014/05/06 PHP
php实现的一个简单json rpc框架实例
2015/03/30 PHP
Laravel路由设定和子路由设定实例分析
2016/03/30 PHP
jQuery不间断滚动效果(模拟百度新闻支持文字/图片/垂直滚动)
2013/02/05 Javascript
关于删除时的提示处理(确定删除吗)
2013/11/03 Javascript
使用JS CSS去除IE链接虚线框的三种方法
2013/11/14 Javascript
浅析jQuery(function(){})与(function(){})(jQuery)之间的区别
2014/01/09 Javascript
javascript学习笔记之10个原生技巧
2014/05/21 Javascript
原生JS绑定滑轮滚动事件兼容常见浏览器
2014/06/30 Javascript
node.js中的querystring.parse方法使用说明
2014/12/10 Javascript
jQuery中mouseover事件用法实例
2014/12/26 Javascript
JavaScript搜索字符串并将搜索结果返回到字符串的方法
2015/04/06 Javascript
Backbone.js的Hello World程序实例
2015/06/19 Javascript
基于jquery插件实现拖拽删除图片功能
2020/08/27 Javascript
简单实现js选项卡切换效果
2017/02/09 Javascript
微信小程序中form 表单提交和取值实例详解
2017/04/20 Javascript
JavaScript基本语法_动力节点Java学院整理
2017/06/26 Javascript
微信小程序 蓝牙的实现实例代码
2017/06/27 Javascript
JS处理数据四舍五入(tofixed与round的区别详解)
2017/10/26 Javascript
js时间戳与日期格式之间相互转换
2017/12/11 Javascript
node作为中间服务层如何发送请求(发送请求的实现方法详解)
2018/01/02 Javascript
在react-router4中进行代码拆分的方法(基于webpack)
2018/03/08 Javascript
彻底揭秘keep-alive原理(小结)
2019/05/05 Javascript
jQuery 动态粒子效果示例代码
2020/07/07 jQuery
JavaScript代码实现简单计算器
2020/12/27 Javascript
[00:27]DOTA2荣耀之路2:Patience from zhou!
2018/05/24 DOTA
举例简单讲解Python中的数据存储模块shelve的用法
2016/03/03 Python
学习python类方法与对象方法
2016/03/15 Python
Python实现读写INI配置文件的方法示例
2018/06/09 Python
使用Python3 poplib模块删除服务器多天前的邮件实现代码
2020/04/24 Python
Canvas系列之滤镜效果
2019/02/12 HTML / CSS
学校万圣节活动方案
2014/02/13 职场文书
公民代理授权委托书
2014/09/24 职场文书
租车协议书
2015/01/27 职场文书
幼儿园秋季开学通知
2015/07/16 职场文书
pandas数值排序的实现实例
2021/07/25 Python