MySQL之日志和mysqlbinlog工具的使用

修改相关变量:
    1.对于开关某个功能,使用SET GLOBAL xxx=xxx即可。
    2.涉及到文件的操作,只能修改配置文件,添加内容到配置文件并重启服务后生效。

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

文件位置:
        默认是存放在数据目录,文件名为SERVERHOSTNAME.err的文件。

相关变量:
        log_error 指定错误日志文件
        log_warning 是否记录警告信息,1表示记录。默认为1。

一般查询日志:
    记录内容:
        查询的操作

文件位置:
        默认是存放在数据目录,文件名为SERVERHOSTNAME.log的文件

相关变量:
        general_log  是否启用一般查询日志,默认是OFF。避免记录大量的io。
        general_log_file 指定一般查询日志文件的位置
        log 是否记录所有语句到日志,默认为OFF。mysql5.6已废弃。

log_output 指定一般查询日志和慢查询日志的输出位置,默认是使用TABLE。在编译时会变为FILE。可以使用TABLE表示记录到表中或者NONE表示不记录。TABLE和FILE可以一起使用,用逗号隔开即可。注意此变量优先级高。一旦设定为NONE,即时general_log设定为ON,也不记录。

sql_log_off 控制是否禁止将一般查询日志信息记录进日志文件,默认为OFF。


慢查询日志:
    记录内容:
        查询时间较长的操作

文件位置:
        默认在数据目录名为SERVERHOSTNAME-slow.log。

相关变量:
        long_query_time 指定查询时长阈值,超过此时间都定义为慢查询。注意此长为实际操作执行的时长而不是cpu执行时长。最小值为0,默认为10,单位为秒,支持毫秒级解析度。

slow_query_log 是否启用慢查询日志,日志的输出位置也取决于log_output的设定。

slow_query_log_file 指定慢查询日志文件位置。
        max_long_data_size
        performance_schema_events_waits_history_long_size 收集事件等待历史的长度

二进制日志:
    记录内容:
        记录任何可能引起数据库变化的操作,包括DDL,DML,授权语句等等。使用mysql独有的二进制格式,为复制和即时点恢复提供支持。

二进制日志的格式:
            基于语句:statment
            基于行:row
            混合方式:mixed

文件头+事件...

事件的组成:
                position:上个事件的结束位置和下个事件的开始位置。
                starttime:事件的起始时间
                action:事件的动作。

文件位置:
        使用工具mysqlbinlog查看,一般的文本编辑文件是无法产看的。


        二进制日志文件:默认在数据目录以mysql-bin或SERVERHOSTNAME开头,末尾为.bin.00000NUM的文件。每次重启服务器后日志将进行滚动。保留旧文件,新创建文件。使用SHOW MASTER STATUS可以查看当前正在使用的文件。使用SHOW BINLOG EVENTS in ‘mysql-bin.00000NUM’ [FROM POSITION] 查看具体内容。日志文件的大小会大于数据的大小,因为里边还记录了其他的额外信息。


        索引文件:记录了二进制日志文件的相关信息。默认在数据目录,名字为mysql-bin.index。

建议将二进制日志文件和数据分开存放在不同磁盘,这样既能保证安全性,又能保证日志文件之间不出现竞争io的情况。

也可以执行FLUSH LOGS来手动滚动日志。注意只有二进制和中继日志才是真的滚动,其他日志都是关闭后打开。

使用SHOW BINARY LOGS查看日志

使用PURGE BINARY LOGS TO ‘BINLOGFILE’ 可以删除指定文件之前的日志文件

相关变量:
        binlog_format STATMENT|ROW|MIXED 指定二进制日志文件的格式

log_bin ON|OFF [FILE] 指定二进制日志文件的位置,没有指定FILE默认写在数据文件下,是否启用二进制日志文件功能。在mysql启动时使用 --log-bin=mysql-bin或者是修改配置文件,在[mysqld]中添加log-bin=mysql-bin和binlog_format=mixed。

sql_log_bin ON|OFF 控制是否将日志写入二进制日志文件

binlog_cache_size 缓存大小,跟随binlog_stmt_cache_size大小变化

binlog_stmt_cache_size 语句缓存大小

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/ac10d6f39e9799db4257ed07d061a990.html