[mysql] 2025-05-03 圈点643
摘要:MySQL日志类型,MySQL日志配置方法,MySQL日志作用,当你执行一个FLUSH LOGS语句或执行mysqladmin flush-logs或mysqladmin refresh时,则日志被老化。
MySQL日志类型和配置方法和作用
a、错误日志:
记录启动、运行或停止mysqld时出现的问题。
默认开启,win下是hostname.err文件。
配置方法:
log-error = filename
b、通用日志:
记录建立的客户端连接和执行的语句。
配置方法:
general_log=0 # 1 为开启;0 为关闭,默认为0
general_log_file = filename
c、更新日志:
记录更改数据的语句。该日志在MySQL 5.1中已不再使用。
d、二进制日志:
记录所有更改数据的语句。还用于复制。
默认是不开启的;
开启方法:
在[mysqld]下面增加
log_bin = filename
使用方法见其它文章。
e、慢查询日志:
记录所有执行时间超过long_query_time秒的所有查询或不使用索引的查询。
可以通过配置进行自定义,即:
long_query_time :慢查询阈值,当查询时间多于设定的阈值时,记录日志。
slow_query_log :是否开启慢查询日志,1表示开启,0表示关闭。默认关闭。
log-slow-queries :旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。
可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
slow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。
可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
f、Innodb日志:innodb redo log
innodb中事务日志ib_logfile
事务日志或称redo日志,在mysql中默认以ib_logfile0,ib_logfile1名称存在,可以手工修改参数,
调节开启几组日志来服务于当前mysql数据库,mysql采用顺序,循环写方式,每开启一个事务时,
会把一些相关信息记录事务日志中(记录对数据文件数据修改的物理位置或叫做偏移量);
作用:在系统崩溃重启时,作事务重做;
在系统正常时,每次checkpoint时间点,会将之前写入事务应用到数据文件中。
备注:
1,当你执行一个FLUSH LOGS语句或执行mysqladmin flush-logs或mysqladmin refresh时,则日志被老化。同步日志缓存到磁盘,关闭当前的日志并产生新的日志文件。
2,提到的filename表示文件保存的路径,若路径中有空格,则需要加双引号“”把路径包起来。
若只给出了文件名(如x.log),没有给出路径则文件路径为data目录
3,另外一个参数:log_output
log_output:日志存储方式。
log_output='FILE'表示将日志存入文件,默认值是'FILE'。
log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。
MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,
如:log_output='FILE,TABLE'。
日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源。
因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。
MySQL日志类型 MySQL日志配置方法 MySQL日志作用