MySQL日志主要包含:错误日志、一般查询日志、慢查询日志、二进制日志 、中继日志、事务日志。

1.错误日志

    错误日志大概记录以下几个方面的信息:服务器启动和关闭过程中的信息(未必是错误信息,如mysql如何启动InnoDB的表空间文件的、如 何初始化自己的存储引擎的等等)、服务器运行过程中的错误信息、事件调度器运行一个事件时产生的信息、在从服务器上启动服务器进程时产生的信息。

    在mysql数据库中,错误日志功能是默认开启的。并且,错误日志无法被禁止。默认情况下,错误日志存储在mysql数据库的数据文件中。错误日志文件通常的名称为hostname.err。其中,hostname表示服务器主机名。

错误日志相关服务器变量:

    log_error=/PATH/TO/ERROR_LOG_FILENAME:定义错误日志文件。作用范围为全局或会话级别,可用于配置文件,属非动态变量。

    log_warnings=#:设定是否将警告信息记录进错误日志。默认设定为1,表示启用;可以将其设置为0以禁用;而其值为大于1的数值时表示将新发起连接时产生的“失败的连接”和“拒绝访问”类的错误信息也记录进错误日志。

2.一般查询日志

    默认情况下查询日志是关闭的。由于查询日志会记录用户的所有操作,其中还包含增删查改等信息,在并发操作大的环境下会产生大量的信息从而导致不必要的磁盘IO,会影响mysql的性能的。

一般查询日志相关服务器变量:

    general_log={ON|OFF}:设定是否启用查询日志,默认值为取决于在启动mysqld时是否使用了--general_log选项。如若启用此项,其输出位置则由--log_output选项进行定义,如果log_output的值设定为NONE,即使用启用查询日志,其也不会记录任何日志信息。作用范围为全局,可用于配置文件,属动态变量。

    general_log_file=FILE_NAME:查询日志的日志文件名称,默认为“hostname.log"。作用范围为全局,可用于配置文件,属动态变量。

    log={YES|NO}:是否启用记录所有语句的日志信息于一般查询日志(general query log)中,默认通常为OFF。MySQL 5.6已经弃用此选项。

   log_output={TABLE|FILE|NONE}:定义一般查询日志和慢查询日志的保存方式,可以是TABLE、FILE、NONE,也可以是TABLE及FILE的组合(用逗号隔开),默认为TABLE。如果组合中出现了NONE,那么其它设定都将失效,同时,无论是否启用日志功能,也不会记录任何相关的日志信息。作用范围为全局级别,可用于配置文件,属动态变量。

3.慢查询日志

    慢查询日志是用来记录执行时间超过指定时间的查询语句。通过慢查询日志,可以查找出哪些查询语句的执行效率很低,以便进行优化。一般建议开启,它对服务器性能的影响微乎其微,但是可以记录mysql服务器上执行了很长时间的查询语句。可以帮助我们定位性能问题的。

慢查询日志相关服务器变量:

    long_query_time=#:设定区别慢查询与一般查询的语句执行时间长度。这里的语句执行时长为实际的执行时间,而非在CPU上的执行时长,因此,负载较重的服务器上更容易产生慢查询。其最小值为0,默认值为10,单位是秒钟。它也支持毫秒级的解析度。作用范围为全局或会话级别,可用于配置文件,属动态变量。

    log_slow_queries={YES|NO}:是否记录慢查询日志。慢查询是指查询的执行时间超出long_query_time参数所设定时长的事件。MySQL 5.6将此参数修改为了slow_query_log。作用范围为全局级别,可用于配置文件,属动态变量。

    slow_query_log={ON|OFF}:设定是否启用慢查询日志。0或OFF表示禁用,1或ON表示启用。日志信息的输出位置取决于log_output变量的定义,如果其值为NONE,则即便slow_query_log为ON,也不会记录任何慢查询信息。作用范围为全局级别,可用于选项文件,属动态变量。

    slow_query_log_file=/PATH/TO/SOMEFILE:设定慢查询日志文件的名称。默认为hostname-slow.log,但可以通过--slow_query_log_file选项修改。作用范围为全局级别,可用于配置文件,属动态变量。

4.二进制日志

    二进制日志也叫作变更日志,主要用于记录修改数据或有可能引起数据改变的操作。

    二进制日志格式:基于语句(statement)、基于行(row)、混合方式(mixed)。

    二进制日志事件:产生的时间(starttime)、相对位置(position)。

    二进制日志相关命令:

mysql> SHOW MASTER STATUS;    #查看当前正在使用的二进制日志文件信息;
mysql> SHOW BINARY LOGS;     #查看当前所有二进制日志文件;
mysql> SHOW BINLOG EVENTS IN '二进制日志文件名' [FROM pos];    #查看二进制日志文件中事件信息;
mysql> PURGE BINARY LOGS TO '某二进制日志文件';    #删除指定二进制日志文件之前的二进制日志文件;
mysql> FLUSH LOGS;    #日志滚动

    命令行下查看二进制日志:

mysqlbinlog --start-datetime='starttime' --stop-datetime='stoptime' 二进制日志文件名
    #time格式为YYYY-MM-DD hh:mm:ss,显示时间starttime和stoptime之间的内容。
    
mysqlbilog --start-position=N --stop-position=M 二进制日志文件名
    #显示起始startposition和stopposition之间的内容
例:
mysqlbinlog --start-position=107 --stop-position=358 mysql-bin.000005
mysqlbinlog --start-datetime='2015-08-22 23:06:33' mysql-bin.000005
mysqlbinlog mysql-bin.000005    #不加参数表示显示全部内容

二进制日志相关服务器变量:

    binlog_format={ROW|STATEMENT|MIXED}:指定二进制日志的类型,默认为STATEMENT。如果设定了二进制日志的格式,却没有启用二进制日志,则MySQL启动时会产生警告日志信息并记录于错误日志中。作用范围为全局或会话,可用于配置文件,且属于动态变量。

    binlog_cache_size=#:二进制日志缓存大小,其上限取决于binlog_stmt_cache_size。

    binlog_stmt_cache_size=#:二进制日志语句缓存大小,就目前来说与binlog_cache_size几乎表示的是同一个意思。

    log_bin={YES|NO}:是否启用二进制日志,如果为mysqld设定了--log-bin选项,则其值为ON,否则则为OFF。其仅用于显示是否启用了二进制日志,并不反应log-bin的设定值。作用范围为全局级别,属非动态变量。

    sql_log_bin={ON|OFF}:用于控制二进制日志信息是否记录进日志文件。默认为ON,表示启用记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。

    sync_binlog=#:设定多久同步一次二进制日志至磁盘文件中,0表示不同步,任何正数值都表示对二进制每多少次写操作之后同步一次。当autocommit的值为1时,每条语句的执行都会引起二进制日志同步,否则,每个事务的提交会引起二进制日志同步。

    max_binlog_cache_size={4096 .. 18446744073709547520}:二进定日志缓存空间大小,5.5.9及以后的版本仅应用于事务缓存,其上限由max_binlog_stmt_cache_size决定。作用范围为全局级别,可用于配置文件,属动态变量。

    max_binlog_size={4096 .. 1073741824}:设定二进制日志文件上限,单位为字节,最小值为4K,最大值为1G,默认为1G。某事务所产生的日志信息只能写入一个二进制日志文件,因此,实际上的二进制日志文件可能大于这个指定的上限。作用范围为全局级别,可用于配置文件,属动态变量。

    expire_logs_days={0..99}:设定二进制日志的过期天数,超出此天数的二进制日志文件将被自动删除。默认为0,表示不启用过期自动删除功能。如果启用此功能,自动删除工作通常发生在MySQL启动时或FLUSH日志时。作用范围为全局,可用于配置文件,属动态变量。

5.中继日志

    从主服务器的二进制日志文件中复制而来的事件,并保存为的日志文件。

6.事务日志

    事务性存储引擎用于保证原子性、一致性、隔离性和持久性。

事务日志相关服务器变量:

    innodb_flush_log_at_trx_commit={0|1|2}:0: 每秒同步(将内存中的日志事件同步到日志文件中),并执行磁盘flush操作;1:每事务同步,并执行磁盘flush操作;2: 每事务同步,但不执行磁盘flush操作。

    innodb_log_buffer_size={262144 .. 4294967295}:设定InnoDB用于辅助完成日志文件写操作的日志缓冲区大小,单位是字节,默认为8MB。较大的事务可以借助于更大的日志缓冲区来避免在事务完成之前将日志缓冲区的数据写入日志文件,以减少I/O操作进而提升系统性能。因此,在有着较大事务的应用场景中,建议为此变量设定一个更大的值。作用范围为全局级别,可用于选项文件,属非动态变量。

    innodb_log_file_size={108576 .. 4294967295}:设定日志组中每个日志文件的大小,单位是字节,默认值是5MB。较为明智的取值范围是从1MB到缓存池体积的1/n,其中n表示日志组中日志文件的个数。日志文件越大,在缓存池中需要执行的检查点刷写操作就越少,这意味着所需的I/O操作也就越少,然而这也会导致较慢的故障恢复速度。作用范围为全局级别,可用于选项文件,属非动态变量。

    innodb_log_files_in_group={2 .. 100}:设定日志组中日志文件的个数。InnoDB以循环的方式使用这些日志文件。默认值为2。作用范围为全局级别,可用于选项文件,属非动态变量。

    innodb_log_group_home_dir=/PATH/TO/DIR:设定InnoDB重做日志文件的存储目录。在缺省使用InnoDB日志相关的所有变量时,其默认会在数据目录中创建两个大小为5MB的名为ib_logfile0和ib_logfile1的日志文件。作用范围为全局级别,可用于选项文件,属非动态变量。

参考资料:

MySQL日志管理:http://blog.itpub.net/29065182/viewspace-1161787/

MySQL日志详解:http://www.cnblogs.com/wangkongming/p/3684950.html