通过日志可以知道mysql内部发生了什么 异常监控、性能优化、数据恢复、主从同步
mysql日志通常包括:二进制日志、通用查询日志、慢查询日志、错误日志、事务日志
4.1 二进制日志
复制,slave端会利用这个二进制日志的信息在本地重做,实现主从同步。
恢复,因为二进制日志包含了备份以后的所有更新,因此可以用于最大限度地恢复数据库。
show variables like ‘log_bin’;//查看二进制日志是否打开
show binary logs;
mysqlbinlog /var/lib/mysql/binlog.000003 查看二进制日志
show binlog events in ‘binlog.000003’\G 查看日志事件
4.2 错误日志
MySQL的错误日志记录了 mysqld 启动和停止时,以及服务器在运行过程中出现的任何严重错误
log-error=
4.3 慢查询日志
set global slow_query_log = on; 打开慢查询日志
set long_query_time = 1; 设置慢查询时间临界点
set globle log_output = file;
show variables like ‘%quer%’;查询慢查询日志的开启状态和慢查询日志储存的位置
4.4 事务日志
可提高事务的效率
1 存储引擎在修改表的数据时只需要修改其内存拷贝
2 写日志的操作是磁盘上一小块区域内的顺序I/O
3 预写式日志 内存中被修改的数据在后台可以慢慢的刷回到磁盘
4 数据本身还没有写回磁盘,此时系统崩溃。恢复后可以根据事务日志回写磁盘