MySQL日志类型和配置方法和作用

[mysql] 2024-04-29 圈点702

摘要: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日志作用  

感谢反馈,已提交成功,审核后即会显示