错误日志(error log)

        记录mysql启动、关闭、运行期间发生的错误及警告相关信息,当mysql出现问题时可通过排查错误日志定位具体问题。

        查看错误日志位置:show  global variables like 'log_error';

        修改错误日志位置:修改my.cnf中log-error路径

通用日志(general log)

        记录服务端收到的每个命令,由于会记录所有命令,开启会对性能造成影响,默认关闭。可通过以下方式配置使用

使用命令
show global variables like  '%general%'; 查看通用日志相关参数
    general_log :是否开启通用日志
    general_log_file 通用日志文件位置

set global general_log=on; -- 开启
set global general_log=off; -- 关闭
set global general_log_file='/data/mysql/log/general.log' -- 设置日志路径

show variables like 'log_output'; -- 查看通用日志记录格式,分为file,与table两种
set global log_output='file'; -- 使用文件方式保存日志
set global log_output='table'; -- 使用表方式保存日志,会保存到mysql库的general_log表中

使用配置文件
[mysqld]
general_log = 1  默认为0不开启,1开启
general_log_file = /data/mysql/log/general.log

慢查询日志(slow query log)

        开启后会记录超过long_query_time查询时间的sql语句,可通过如下方式使用

使用命令
show global variables like '%slow%'; -- 查看慢查询日志相关配置
     log_slow_admin_statements :ddl慢查询是否开启          
     log_slow_slave_statements :从库慢查询是否开启                   
     slow_launch_time :创建线程的阈值,超过该时间slow_launch_time+1                            
     slow_query_log :慢查询是否开启                      
     slow_query_log_file:慢查询日志位置

show global variables like 'long_query_time'; -- 查看慢查询时间
set global long_query_time=3; -- 设置慢查询时间
set global slow_query_log=on; -- 开启
set global slow_query_log=off; -- 关闭
set global slow_query_log_file='/data/mysql/log/slow.log' -- 设置日志路径

show variables like 'log_output'; -- 查看日志记录格式,分为file,与table两种
set global log_output='file'; -- 使用文件方式保存日志
set global log_output='table'; -- 使用表方式保存日志,会保存到mysql库的slow_log表中


使用配置文件
[mysqld]
slow_query_log = 1 0不开启,1开启
slow_query_log_file = /data/mysql/log/slow.log 
long_query_time = 3

中继日志(relay log)        

        用于主从同步,从库读取主库二进制日志并且保存到本地,然后从库线程读取relay log日志内容在从库中执行。日志格式与binlog相同可通过mysqlbinlog读取

使用命令
show global variables like '%relay%'; -- 查看中继日志相关配置
    max_relay_log_size :日志最大值,为0时等于max_binlog_size,不为0时,当日志超过此大小循环写入。      
    relay_log:中继日志名称,为空是在数据文件目录下,文件名为host_name-relay-bin            
    relay_log_basename:中继日志文件的基本名称和完整路径    
    relay_log_index:中继日志索引文件的名称           
    relay_log_info_file :设置relay-log.info的位置和名称     
    relay_log_info_repository :中继日志类型table或file 
    relay_log_purge:是否自动清空中继日志,默认开启          
    relay_log_recovery :从库宕机,relay log损坏,导致一部分中继日志没处理,则放弃所有未执行的relay log,重新从主库获取,使用时需要开启relay_log_purge       
    relay_log_space_limit :中继日志的最大空间量   
    sync_relay_log:刷盘策略,为0时不主动刷盘,依赖操作系统定期刷盘,为1时表示每次写入都刷盘      
    sync_relay_log_info:与sync_relay_log类似,刷盘时机取决于是否有事务

可通过 set global修改对应参数
set global sync_relay_log=1; -- 修改刷盘策略
set global relay_log_purge=off; -- 关闭




使用配置文件
[mysqld]
relay_log_purge= 1 0不开启,1开启
sync_relay_log= 1

回滚日志(undo log)

        innodb 特有,在数据变动时,将对变动进行逆向记录,用来保证事务原子性以及实现mvcc。

show global variables like '%undo%'; 
    innodb_max_undo_log_size :日志最大值,默认1G,开启innodb_undo_log_truncate后会进行自动回收
    innodb_undo_directory:日志位置,默认数据目录(datadir)下           
    innodb_undo_log_truncate:是否开启自动回收。开启后需要innodb_undo_tablespaces大于2才可以回收。   
    innodb_undo_logs:回滚段数量默认为128,innodb_undo_logs>=35,32个给临时表空间使用,1个给系统表空间使用,2个给自动回收表空间使用,由于每个回滚段由1024个undo segment组成,该值为128则最大事务为 93*1024
    innodb_undo_tablespaces:表示undolog对应的表空间文件的个数

重做日志(redo log)

        innodb 特有的引擎层物理日志,用来保证事务持久性,redo log 包括内存缓冲区(innodb_log_buffer_size)与磁盘日志文件(innodb_log_file_size ),在写磁盘日志文件时采用循环写入方式,当写到结尾时,会回到文件头覆盖写入。由于磁盘日志为顺序写入,可以提高性能。

show global variables like '%innodb_flush_log_at_trx_commit%'; -- 查看redo log 刷盘策略,
为0时表示每次事务提交都把写入redo log buffer中
为1时每次事务提交都写入 redo log file中进行刷盘,保证数据一致性
为2时每次提交事务都写入redo log file中但是不进行刷盘,此时数据在磁盘缓存(page chche)中

show global variables like '%innodb_flush_log_at_timeout%';
日志刷盘时间,默认1秒


show global variables like '%innodb_log%';
    innodb_log_buffer_size:redo log内存区大小
    innodb_log_checksums:是否启用重做日志的校验
    innodb_log_compressed_pages:是否启用压缩
    innodb_log_file_size:每个日志文件大小
    innodb_log_files_in_group:日志文件数量,可在innodb_log_group_home_dir下查看,默认两个ib_logfile0,ib_logfile1
    innodb_log_group_home_dir:日志文件路径
    innodb_log_write_ahead_size:预写块大小,以字节为单位。避免read-on-write

二进制日志(binlog)

        server层逻辑日志,记录sql语句的逻辑,在事务执行过程中,先写入到binlog cache,事务提交时再把binlog cache写入到binlog文件中,之后删除binglog cache中内容,当binlog cache不够大时,会先写入磁盘临时文件。binlog文件为追加写入,当文件写到一定大小写下一个文件。

        

SHOW GLOBAL  VARIABLES LIKE "%binlog%"
    binlog_cache_size:每个线程binlog cache 大小,必须是4096倍数
    binlog_checksum:验证算法,默认为crc32,为每一个binlog event写一个校验码,设置为none时只校验长度,不生成校验码。
    binlog_direct_non_transactional_updates:对非事务表操作是否记入binlog,个人理解用处不大,此参数只在binlog_format为statement时生效。
    binlog_error_action:默认为ABORT_SERVER写入binlog失败时主动关闭实例,重启时恢复,也可设置为IGNORE_ERROR写入binlog失败时不写入,继续对外提供服务
    binlog_format:分为statement,row,mixed格式,
        statement记录sql不保证数据一致性。
        row记录行记录,但比较费空间,保证数据 一致性。
        mixed为混合模式,由mysql判断存储sql还是行记录。
    binlog_group_commit_sync_delay:组提交延迟时间。
    binlog_group_commit_sync_no_delay_count:组提交延迟数量,累计到延迟数量忽略组提交延迟时间设置。
    binlog_gtid_simple_recovery:是否开启gtid简单恢复。
    binlog_order_commits:binlog记录顺序是否与事务顺序相同。
    binlog_row_image:控制binlog记录详细程度,binglog记录为row格式下生效
        full :记录一行数据所有列信息。
        minimal :只记录该行唯一表示和被修改的信息
        noblob :记录一行数据所有列信息BLOB 和 TEXT类型除外
    binlog_rows_query_log_events:对于row格式的binlog模式,是否记录binlog对应的SQL
    binlog_stmt_cache_size:线程私有,控制事务里有非事务语句缓存区大小。
    binlog_transaction_dependency_history_size:保存事务哈希值上限
    max_binlog_cache_size:与binlog_cache_size类似,每个线程binglog cache超过max_binlog_cache_size设置会抛异常。
    max_binlog_size:binlog日志文件大小,超过此值会打开新文件继续写入。
    max_binlog_stmt_cache_size:与binlog_stmt_cache_size类似,超过会抛异常
    sync_binlog:binlog:刷盘策略
        sync_binlog=0,禁止binlog刷盘,依赖操作系统刷盘。
        sync_binlog=1,每次提交事务都进行刷盘。
        sync_binlog=N,写入N次进行刷盘。

SHOW GLOBAL  VARIABLES LIKE "%log_bin%"
    log_bin:是否开启binglog
    log_bin_basename:binlog文件路径名称
    log_bin_index: binglog:索引文件路径名称
    log_bin_trust_function_creators:是否可以信任存储函数创建者,不会创建写入二进制日志引起不安全事件的存储函数。
    log_bin_use_v1_row_events:是否启用版本2日志记录,mysql5.6.6以前使用版本1

 set global设置参数到内存中,重启失效,并且有些不能通过set global修改,需要修改my.cnf文件