是MySQL中最重要的日志,当MySQL服务启动中止时,以及其余运行过程当中发生错误的信息,能够查看此日志。mysql
show variables like 'log_error';
二进制日志(binLog)记录了全部DLL语句(数据库表结构以及定义),还有DML语句(数据操做语言)增删改。sql
二进制日志默认没有开启,须要本身打开数据库
先找到MySQL配置文件地址工具
#配置开启binlog日志, 日志的文件前缀为 mysqlbin -----> 生成的文件名如 : mysqlbin.000001,mysqlbin.000002 log_bin=mysqlbin #配置二进制日志的格式 binlog_format=STATEMENT //四个参数能够配置
记录的都是SQL语句,当数据进行修改都会被记录,在主从复制的时候,会将日志解析成为源文本,再执行一遍。日志
查看日志文件 :code
mysqlbin.index : 该文件是日志索引文件 , 记录日志的文件名;orm
mysqlbing.000001 :日志文件blog
查看日志内容 :索引
mysqlbinlog mysqlbing.000001;
会记录每一行的数据变化,假如更新整个表,会记录每一行的数据变动。it
若是日志格式是 ROW , 直接查看数据 , 是查看不懂的 ; 能够在mysqlbinlog 后面加上参数 -vv
mysqlbinlog -vv mysqlbin.000002
这是默认的数据格式,就是混合了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.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 工具, 来对慢查询日志进行分类汇总。