MySQL日志管理
MySQL日志管理
查询有关日志的变量:show global variables like '%log%' ;
特别提醒: 如果不明白mysql中的变量请点击 找到其中的 ”mysql服务器变量“ 部分
错误日志:
记录内容: 服务器启动和关闭过程中的信息
服务器运行过程中的错误信息
事件调度器运行一个事件时产生的信息
在从服务器上启动从服务器进程时产生的信息
1. log_error=文件路径/文件名 : 定义错误日志文件,作用范围为全局或会话级别 ,可用于配置文件,属于非动态变量
2. log_warnings= :设定是否将警告信息记录进错误日志,1为启用(默认),0为禁用,而其值为大于1的数值时表示将新发起连接时产生的"失败连接"和"拒绝访问"也记录进错误日志
一般查询日志:
记录内容: 每执行一个select 语句,都把相关信息记录下来 ,当 log=yes 时(5.6已经弃用) 执行dml语句都会记录到一般查询日志中
1. general_log={ON|OFF} : 设定是否启用查询日志,默认值为取决于在启动mysqld时是否使用了–general_log选项。如若启用此项,其输出位置则由–log_output选项进行定义,如果log_output的值设定为NONE,即使用启用查询日志,其也不会记录任何日志信息。作用范围为全局,可用于配置文件,属动态变量。
2. general_log_file=文件路径/文件名 : 定义查询日志文件,默认为“hostname.log” 作用范围为全局 可用于配置文件,属于动态变量
3. log={YES|NO} : 是否启用记录所有语句的日志信息于一般查询日志中,默认为OFF,5.6已经弃用
4. log_output={TABLE|FILE|NONE} : 定义一般查询日志和慢查询日志的保存方式,可以是TABLE,FILE,NONE也可以是TABLE及FILE的组合(用逗号隔开),默认为TABLE,如果出现了NONE,那么其他设定都将失效,同时无论是否启用日志功能,也不会记录任何相关信息。作用范围为全局 可用于配置文件,属于动态变量
慢查询日志:(慢查询是指查询的执行时长超过long_query_time参数所设定时长的事件)
1. long_query_time= : 查询时长超过long_query_time指定的时长的就为慢查询, 这里的语句执行的时长为实际的执行时间,而非在cpu上的执行时间,默认为10秒钟,因此,负载较重的服务器上更容易产生慢查询。其最小值为0,默认值为10,单位是秒钟。它也支持毫秒级的解析度。作用范围为全局或会话级别,可用于配置文件,属动态变量。
2. log_slow_queries={YES|NO} :是否记录慢查询日志,。慢查询是指查询的执行时间超出long_query_time参数所设定时长的事件, 5.6将其该为了 slow_query_log ,作用范围为全局级别,可用于配置文件,属动态变量
3. slow_query_log={ON|OFF} : 设定是否启用慢查询日志,0或OFF表示禁用,1或ON 表示启用,日志的输出位置取决于log__output变量的定义,如果其值为NONE即使slow_query_log为ON,也不会记录任何慢查询信息, 作用范围为全局 可用于配置文件,属于动态变量
4. slow_query_log_file=文件路径/位置 : 设定慢查询日志文件的名称。默认为hostname-slow.log,但可以通过–slow_query_log_file选项修改。作用范围为全局级别,可用于选项文件,属动态变量。
二进制日志:
记录内容: 任何引起或可能引起数据库变化的操作;
用于复制、即时点恢复;
只要重启mysql,二进制日志都会滚动
1. binlog_format= : 二进制文件的格式
二进制日志的格式:
基于语句: statement
基于行: row
混合方式: mixed
二进制日志事件格式(在文件中是怎么储存某个事件的):
事件产生的时间 starttime
事件相对位置(事件的开始位置是上个事件的结束位置) position
二进制日志文件有两类:
索引文件 : 记录着能被服务器找的二进制文件
二进制日志文件
查看当前正在使用的二进制日志文件: SHOW MASTER STATUS;
查看二进制日志文件: SHOW BINARY LOGS;
查看事件:SHOW BINLOG EVENTS IN '二进制日志文件名' [FROM 指定开始位置];
删除指定二进制文件之前的日志文件 : PURGE BINARY LOGS TO '二进制日志文件'
滚动二进制日志或中继日志:FLUSH LOGS;
查看mysql二进制文件 : mysqlbinlog [ [----start-datetime] [-stop-datetime] ] [ [--start-position ] [ --stop-position] ]
--start-datetime : 指定开始时间
--stop-datetime : 指定结束时间
--start-position : 指定开始位置
--stop-position : 指定结束位置
中继日志
从主服务器的二进制日志文件中复制而来的事件,并保存为日志文件;
事务日志:
ib_logfile0
ib_logfile1
ACID,将随机IO转换为顺序IO;
事务性存储引擎用于保证原子性、一致性、隔离性和持久性;
innodb_flush_log_at_trx_commit:
0: 每秒同步,并执行磁盘flush操作;
1:每事务同步,并执行磁盘flush操作;
expire_logs_days={0..99}
是否启用二进制日志,如果为mysqld设定了–log-bin选项,则其值为ON,否则则为OFF。其仅用于显示是否启用了二进制日志,并不反应log-bin的设定值。作用范围为全局级别,属非动态变量。
log_bin_trust_function_creators={TRUE|FALSE}
log_query_not_using_indexes={ON|OFF}
设定是否将没有使用索引的查询操作记录到慢查询日志。作用范围为全局级别,可用于配置文件,属动态变量。
log_slave_updates
用于设定复制场景中的从服务器是否将从主服务器收到的更新操作记录进本机的二进制日志中。本参数设定的生效需要在从服务器上启用二进制日志功能。
max_binlog_cache_size{4096 .. 18446744073709547520}
二进定日志缓存空间大小,5.5.9及以后的版本仅应用于事务缓存,其上限由max_binlog_stmt_cache_size决定。作用范围为全局级别,可用于配置文件,属动态变量。
max_binlog_size={4096 .. 1073741824}
innodb_log_buffer_size={262144 .. 4294967295}
innodb_log_file_size={108576 .. 4294967295}
设定日志组中日志文件的个数。InnoDB以循环的方式使用这些日志文件。默认值为2。作用范围为全局级别,可用于选项文件,属非动态变量。
innodb_log_group_home_dir=/PATH/TO/DIR
relay_log=file_name
设定中继日志的文件名称,默认为host_name-relay-bin。也可以使用绝对路径,以指定非数据目录来存储中继日志。作用范围为全局级别,可用于选项文件,属非动态变量。
relay_log_index=file_name
设定中继日志的索引文件名,默认为为数据目录中的host_name-relay-bin.index。作用范围为全局级别,可用于选项文件,属非动态变量。
relay-log-info-file=file_name
设定中继服务用于记录中继信息的文件,默认为数据目录中的relay-log.info。作用范围为全局级别,可用于选项文件,属非动态变量。
relay_log_purge={ON|OFF}
设定对不再需要的中继日志是否自动进行清理。默认值为ON。作用范围为全局级别,可用于选项文件,属动态变量。
relay_log_space_limit=#
设定用于存储所有中继日志文件的可用空间大小。默认为0,表示不限定。最大值取决于系统平台位数。作用范围为全局级别,可用于选项文件,属非动态变量。
slow_query_log={ON|OFF}
设定是否启用慢查询日志。0或OFF表示禁用,1或ON表示启用。日志信息的输出位置取决于log_output变量的定义,如果其值为NONE,则即便slow_query_log为ON,也不会记录任何慢查询信息。作用范围为全局级别,可
用于选项文件,属动态变量。
sql_log_bin={ON|OFF}
用于控制二进制日志信息是否记录进日志文件。默认为ON,表示启用记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。
sql_log_off={ON|OFF}
用于控制是否禁止将一般查询日志类信息记录进查询日志文件。默认为OFF,表示不禁止记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。
sync_binlog=#
设定多久同步一次二进制日志至磁盘文件中,0表示不同步,任何正数值都表示对二进制每多少次写操作之后同步一次。当autocommit的值为1时,每条语句的执行都会引起二进制日志同步,否则,每个事务的提交会引>起二进制日志同步。
MyISAM:
不支持事务
表锁
不支持外键
B树索引、FULLTEXT索引、空间索引
支持表压缩
.frm
.MYD
.MYI
InnoDB:
事务
行级锁
B树索引、聚簇索引、自适应hash索引
表空间,raw磁盘设备;
.frm
.ibd