MySQL的日志文件是数据库管理、故障恢复、性能分析和数据安全的关键组成部分。以下是MySQL主要日志文件的详解:
hostname.errSHOW VARIABLES LIKE 'log_error';
-- 查看配置
SHOW VARIABLES LIKE 'log_bin%';
SHOW VARIABLES LIKE 'binlog_format';
-- 查看binlog文件列表 SHOW BINARY LOGS;
-- 查看binlog内容(命令行) mysqlbinlog mysql-bin.000001
### 3. **查询日志 (General Query Log)**
- **作用**:记录所有客户端连接和执行的SQL语句
- **注意**:对性能有影响,生产环境慎用
- **配置**:
```sql
-- 开启查询日志
SET GLOBAL general_log = 'ON';
-- 查看状态
SHOW VARIABLES LIKE 'general_log%';
-- 查看配置
SHOW VARIABLES LIKE 'slow_query_log%';
SHOW VARIABLES LIKE 'long_query_time';
-- 设置慢查询阈值(秒) SET GLOBAL long_query_time = 2;
### 5. **重做日志 (Redo Log)**
- **作用**:
- InnoDB特有,保证事务的持久性
- 采用WAL(Write-Ahead Logging)机制
- 用于崩溃恢复
- **组成**:
- ib_logfile0, ib_logfile1(循环写入)
- **配置**:
```sql
SHOW VARIABLES LIKE 'innodb_log%';
-- 清理二进制日志(删除指定文件之前的所有日志)
PURGE BINARY LOGS TO 'mysql-bin.000010';
-- 按时间清理
PURGE BINARY LOGS BEFORE '2024-01-01 00:00:00';
-- 设置过期时间
SET GLOBAL binlog_expire_logs_seconds = 604800; -- 7天
-- 查看数据目录
SHOW VARIABLES LIKE 'datadir';
-- 所有日志相关变量
SHOW VARIABLES LIKE '%log%';
# my.cnf配置文件示例
[mysqld]
# 错误日志
log_error = /var/log/mysql/error.log
# 二进制日志
log_bin = /var/log/mysql/mysql-bin.log
binlog_format = ROW
expire_logs_days = 7
max_binlog_size = 100M
# 慢查询日志
slow_query_log = 1
slow_query_log_file = /var/log/mysql/slow.log
long_query_time = 2
log_queries_not_using_indexes = 0
# 重做日志大小(建议设置足够大)
innodb_log_file_size = 1G
innodb_log_files_in_group = 2
-- 查看当前日志状态
SHOW MASTER STATUS;
SHOW SLAVE STATUS;
-- 查看最近错误
SHOW ERRORS;
SHOW WARNINGS;
-- 分析慢查询
mysqldumpslow /var/log/mysql/slow.log
-- 使用pt-query-digest分析(Percona Toolkit)
pt-query-digest /var/log/mysql/slow.log
binlog_expire_logs_seconds替代expire_logs_days合理配置和管理MySQL日志对于数据库的稳定性、性能和数据安全至关重要。建议根据实际业务需求调整日志配置,并建立完善的日志监控和维护流程。