mysql 客户端连接日志_MySQL 日志详解

一、MySQL 日志分类

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

错误日志: -log-err (记录启动、运行、停止 MySQL 服务时出现的信息)

查询日志:-log  (记录建立的客户端连接和执行的语句)

慢查询日志:-log-slow-queries (记录所有执行超过 long_query_time 秒的所有查询)

二进制日志:-log-bin (记录所有更改数据的语句,还用于复制、恢复数据库)

事务日志:  (InnoDB 特有的日志,可以帮助提高事务的效率)

其中,更新日志:-log-update (二进制日志已经代替了老的更新日志,更新日志在 MySQL 5.1 中不再使用)

1、错误日志

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

错误日志可以自己配置,错误日志可以通过log-error和log-warnings来定义,其中log-error:配置是否启用错误日志功能和错误日志的存储位置?log-warning:配置是否将警告信息也定义至错误日志中?

错误日志记录信息:服务器启动关闭信息、运行错误信息、时间调度器运行一个事件时产生的信息、在服务器上启动进程产生的信息。

2、查询日志

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

3、慢查询日志

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

4、事务日志

事务日志(InnoDB特有的日志)可以帮助提高事务的效率。使用事务日志,存储引擎在修改表的数据时只需要修改其内存拷贝,再把改修改行为记录到持久在硬盘上的事务日志中,而不用每次都将修改的数据本身持久到磁盘。事务日志采用追加的方式,因此写日志的操作是磁盘上一小块区域内的顺序I/O,而不像随机I/O需要在磁盘的多个地方移动磁头,所以采用事务日志的方式相对来说要快得多。事务日志持久以后,内存中被修改的数据在后台可以慢慢的刷回到磁盘。目前大多数的存储引擎都是这样实现的,我们通常称之为预写式日志,修改数据需要写两次磁盘。如果数据的修改已经记录到事务日志并持久化,但数据本身还没有写回磁盘,此时系统崩溃,存储引擎在重启时能够自动恢复这部分修改的数据。具有的恢复方式则视存储引擎而定。

5、二进制日志

二进制日志也叫作变更日志,主要用于记录修改数据或有可能引起数据改变的mysql语句,并且记录了语句发生时间、执行时长、操作的数据等等。所以说通过二进制日志可以查询mysql数据库中进行了哪些变化。一般大小体积上限为1G。

标签:事务,log,错误,查询,详解,MySQL,日志

来源: https://www.cnblogs.com/morgan363/p/13300048.html

你可能感兴趣的:(mysql,客户端连接日志)