MySQL日志

MySQL日志

1.1错误日志

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

show variables like 'log_error';

image-20210212151732602

2.2 二进制日志

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

二进制日志默认没有开启,须要本身打开数据库

先找到MySQL配置文件地址工具

#配置开启binlog日志, 日志的文件前缀为 mysqlbin -----> 生成的文件名如 : mysqlbin.000001,mysqlbin.000002
log_bin=mysqlbin

#配置二进制日志的格式
binlog_format=STATEMENT //四个参数能够配置
日志格式
STATEMENT

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

查看日志文件 :code

1554079717375

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

mysqlbing.000001 :日志文件blog

查看日志内容 :索引

mysqlbinlog mysqlbing.000001;
ROW

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

若是日志格式是 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 管理日志的工做量。

配置以下 :

1554125506938

查询日志

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

默认状况下, 查询日志是未开启的。若是须要开启查询日志,能够设置如下配置 :

#该选项用来开启查询日志 , 可选值 : 0 或者 1 ; 0 表明关闭, 1 表明开启 
general_log=1
#设置日志的文件名 , 若是没有指定, 默认的文件名为 host_name.log 
general_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

# 该选项用来配置查询的时间限制, 超过这个时间将认为值慢查询, 将须要进行日志记录, 默认10s
long_query_time=10

若是慢查询日志内容不少, 直接查看文件,比较麻烦, 这个时候能够借助于mysql自带的 mysqldumpslow 工具, 来对慢查询日志进行分类汇总。

相关文章
相关标签/搜索