《SQL与数据库基础》19. 日志
创始人
2024-06-01 22:04:45
0

SQL - 日志

  • 日志
    • 错误日志
    • 二进制日志
      • 日志格式
      • 日志查看
      • 日志删除
    • 查询日志
    • 慢查询日志


本文以 MySQL 为例

日志

错误日志

错误日志是 MySQL 中最重要的日志之一,它记录了当 mysql 启动和停止时,以及服务器在运行过程中发生任何严重错误时的相关信息。

当数据库出现任何故障导致无法正常使用时,建议首先查看此日志。

该日志是默认开启的,默认存放目录 /var/log/,默认的日志文件名为 mysqld.log

查看日志相关信息
SHOW VARIABLES LIKE '%log_error%';

二进制日志

二进制日志(BINLOG)记录了所有的 DDL(数据定义语言)语句和 DML(数据操纵语言)语句,但不包括数据查询(SELECT、SHOW)语句。

作用

  • 灾难时的数据恢复
  • MySQL的主从复制

在 MySQL8 版本中,默认二进制日志是开启着的

查看日志相关信息
SHOW VARIABLES LIKE '%log_bin%';

参数说明:

  • log_bin_basename:当前数据库服务器的 binlog 日志的基础名称(前缀),具体的 binlog 文件名需要在该 basename 的基础上加上编号(编号从000001开始)。
  • log_bin_index:binlog的索引文件,里面记录了当前服务器关联的 binlog 文件有哪些。

日志格式

MySQL服务器中提供了多种格式来记录二进制日志。

查看日志格式
SHOW VARIABLES LIKE '%binlog_format%';

具体格式及特点如下:

日志格式含义
STATEMENT基于SQL语句的日志记录,记录的是SQL语句,对数据进行修改的SQL都会记录在日志文件中。
ROW基于行的日志记录,记录的是每一行的数据变更。(默认)
MIXED混合了STATEMENT和ROW两种格式,默认采用STATEMENT,在某些特殊情况下会自动切换为ROW进行记录。

如果需要配置二进制日志的格式,只需要在 /etc/my.cnf 中配置 binlog_format 参数即可。

日志查看

由于日志是以二进制方式存储的,不能直接读取,需要通过二进制日志查询工具 mysqlbinlog(命令行)来查看。

基础语法
mysqlbinlog [参数选项] logfilename

参数选项:

-d     指定数据库名称,只列出指定的数据库相关操作。
-o     忽略掉日志中的前n行命令。
-v     将行事件(数据变更)重构为SQL语句。
-vv    将行事件(数据变更)重构为SQL语句,并输出注释信息。

日志删除

对于比较繁忙的业务系统,每天生成的binlog数据巨大,如果长时间不清除,将会占用大量磁盘空间。

可以通过以下几种指令清理日志(指令为 mysql 语句):

指令含义
reset master删除全部 binlog 日志,删除之后,日志编号将从 binlog.000001 重新开始
purge master logs to 'binlog.编号'删除指定编号之前的所有日志
purge master logs before 'yyyy-mm-dd hh24:mi:ss'删除日志为“yyyy-mm-dd hh24:mi:ss”之前产生的所有日志

也可以在mysql的配置文件中配置二进制日志的过期时间,设置之后,二进制日志过期会自动删除。

查看日志过期时间
SHOW VARIABLES LIKE '%binlog_expire_logs_seconds%';

查询日志

查询日志中记录了客户端的所有操作语句,而二进制日志不包含查询数据的SQL语句。默认情况下,查询日志是未开启的。

查看日志相关信息
SHOW VARIABLES LIKE 'general';

如果需要开启查询日志,可以修改MySQL的配置文件 /etc/my.cnf 文件,添加如下内容:

# 该选项用来开启查询日志,可选值:0 或者 1;0 代表关闭,1 代表开启
general_log=1# 设置日志的文件名,如果没有指定,默认的文件名为 host_name.log
general_log_file=mysql_query.log

开启了查询日志之后,在MySQL的数据存放目录,也就是 /var/lib/mysql/ 目录下就会出现查询日志文件。之后所有的客户端的增删改查操作都会记录在该日志文件之中,长时间运行后,该日志文件将会非常大。

慢查询日志

慢查询日志记录了所有执行时间超过参数 long_query_time 设置的值,并且扫描记录数不小于 min_examined_row_limit 的所有的SQL语句的日志,默认未开启。

long_query_time 默认为10 秒,最小为 0,精度可以到微秒。

如果需要开启慢查询日志,需要在MySQL的配置文件 /etc/my.cnf 中配置如下参数:

# 慢查询日志
slow_query_log=1# 执行时间参数
long_query_time=2

默认情况下,慢查询日志不会记录管理语句,也不会记录不使用索引进行查找的查询。可以使用 log_slow_admin_statements 和 log_queries_not_using_indexes 更改此行为 ,如下所述:

# 记录执行较慢的管理语句
log_slow_admin_statements=1# 记录执行较慢的未使用索引的语句
log_queries_not_using_indexes=1

本文中提到的所有的参数配置完成之后,都需要重新启动MySQL服务器才可以生效。

相关内容

热门资讯

云南澜沧江导游词 云南澜沧江导游词  澜沧江是湄公河上游在中国境内河段的名称,藏语拉楚,意思为“獐子河”。它也是中国西...
新疆概况旅游导游词 新疆概况旅游导游词范文(精选3篇)  作为一名尽职尽责的导游,有必要进行细致的导游词准备工作,借助导...
颐和园的导游词资料 关于颐和园的导游词资料  导游词是导游人员引导游客观光游览时的讲解词,是导游员同游客交流思想,向游客...
北京导游词 北京导游词(合集15篇)  作为一名优秀的旅游从业人员,时常要开展导游词准备工作,一篇完整的导游词,...
泰山景点介绍导游词 泰山景点介绍导游词(通用5篇)  作为一位不辞辛劳的导游,通常需要准备好一份导游词,导游词可以加深游...
校园导游词 校园导游词  作为一名专门引导游客、助人为乐的导游,就难以避免地要准备导游词,导游词一般是根据实际的...
韩国景点导游词 韩国景点导游词  大家好!  首先,欢迎大家到韩国首尔来旅游,下面就由我给大家介绍一下这个具有东方神...
介绍洛阳的导游词 介绍洛阳的导游词  洛阳位于河南,在那里有许多的特色文化,那么关于介绍洛阳的导游词都有哪些呢?下面是...
桂林聚龙潭导游词 桂林聚龙潭导游词  作为一位无私奉献的导游,时常需要用到导游词,导游词不是以一代百、千篇一律的,它必...
炳灵寺石窟导游词 炳灵寺石窟导游词  作为一名尽职尽责的导游,常常要根据讲解需要编写导游词,导游词是导游人员引导游客观...
西安大雁塔导游词 西安大雁塔导游词500字  游客朋友们:  大家好!  欢迎大家到西安大雁塔观光旅游!  大雁塔位于...
马鞍山森林公园讲解词 马鞍山森林公园讲解词  森林公园的导游词篇一:马鞍山森林公园导游词  大家好!欢迎来到马鞍山森林公园...
武汉导游词 武汉导游词范文(精选8篇)  作为一无名无私奉献的导游,时常需要用到导游词,导游词是导游员进行实地口...
大慈岩导游词 大慈岩导游词五篇  篇一:大慈岩导游词  大慈岩概况 在前面大家可以往右看一下。我们会看到在山腰上有...
五爷庙和杨五郎的关系导游词 五爷庙和杨五郎的关系导游词  一提起五台山,就知道它是五台山香火最旺,许愿最灵的寺庙。万佛阁是五爷庙...
优秀导游词 优秀导游词(精选35篇)  作为一名优秀的旅游从业人员,就有可能用到导游词,导游词是导游人员引导游客...
百里峡导游词 百里峡导游词精选  尊敬的各位朋友:  大家好!  欢迎来到祖冲之的故乡、山水休闲的胜地、美丽而热情...
屈原祠导游词 屈原祠导游词  作为一名专门为游客提供帮助的导游,编写导游词是必不可少的,导游词是导游员同游客交流思...
描写花果山导游词 描写花果山导游词  导语:花果山位于连云港市南云台山中麓。如下是精心为你挑选的关于花果山的导游词,欢...
拉法山导游词 拉法山导游词五篇  作为一名可信赖的导游人员,常常需要准备导游词,导游词作为一种解说的文体,它的作用...