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 工具, 来对慢查询日志进行分类汇总。