AI智能
改变未来

MySQL日志


MySQL日志

[TOC]

1.1错误日志

是MySQL中最重要的日志,当MySQL服务启动停止时,以及其他运行过程中发生错误的信息,可以查看此日志。

show variables like \'log_error\';

2.2 二进制日志

二进制日志(binLog)记录了所有DLL语句(数据库表结构以及定义),还有DML语句(数据操作语言)增删改。

二进制日志默认没有开启,需要自己打开

先找到MySQL配置文件地址

#配置开启binlog日志, 日志的文件前缀为 mysqlbin -----> 生成的文件名如 : mysqlbin.000001,mysqlbin.000002log_bin=mysqlbin#配置二进制日志的格式binlog_format=STATEMENT //四个参数可以配置
日志格式

STATEMENT

记录的都是SQL语句,当数据进行修改都会被记录,在主从复制的时候,会将日志解析成为源文本,再执行一遍。

查看日志文件 :

mysqlbin.index : 该文件是日志索引文件 , 记录日志的文件名;

mysqlbing.000001 :日志文件

查看日志内容 :

mysqlbinlog mysqlbing.000001;

ROW

会记录每一行的数据变化,假如更新整个表,会记录每一行的数据变更。

如果日志格式是 ROW , 直接查看数据 , 是查看不懂的 ; 可以在mysqlbinlog 后面加上参数 -vv

mysqlbinlog -vv mysqlbin.000002

MIXED

这是默认的数据格式,就是混合了STATEMENT和ROW两种格式,默认情况下采用STATEMENT,但是在特殊情况下会用ROW,MIXED能采用他们的优点,避免缺点。

日志删除

比较大的系统,如果日志不进行删除会消耗大量磁盘空间。

方式一

通过Reset Master指令删除全部binlog日志,删除以后将从xxxx.0000001开始

Reset Master //删除指令

方式二

执行指令

purge master logs to \'mysqlbin.******\'

,该命令将删除

******

编号之前的所有日志。

方式三

执行指令

purge master logs before \'yyyy-mm-dd hh24:mi:ss\'

,该命令将删除日志为 "yyyy-mm-dd hh24:mi:ss" 之前产生的所有日志 。

方式四

设置参数 –expire_logs_days=# ,此参数的含义是设置日志的过期天数, 过了指定的天数后日志将会被自动删除,这样将有利于减少DBA 管理日志的工作量。

配置如下 :

查询日志

查询日志中记录了客户端的所有操作语句,而二进制日志不包含查询数据的SQL语句。

默认情况下, 查询日志是未开启的。如果需要开启查询日志,可以设置以下配置 :

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

慢查询日志记录了所有执行时间超过参数 long_query_time 设置值并且扫描记录数不小于 min_examined_row_limit 的所有的SQL语句的日志。long_query_time 默认为 10 秒,最小为 0, 精度可以到微秒。

文件格式和日志

慢查询日志默认是关闭的 。可以通过两个参数来控制慢查询日志 :

# 该参数用来控制慢查询日志是否开启, 可取值: 1 和 0 , 1 代表开启, 0 代表关闭slow_query_log=1# 该参数用来指定慢查询日志的文件名slow_query_log_file=slow_query.log# 该选项用来配置查询的时间限制, 超过这个时间将认为值慢查询, 将需要进行日志记录, 默认10slong_query_time=10

如果慢查询日志内容很多, 直接查看文件,比较麻烦, 这个时候可以借助于mysql自带的 mysqldumpslow 工具, 来对慢查询日志进行分类汇总。

赞(0) 打赏
未经允许不得转载:爱站程序员基地 » MySQL日志