数据库日志是运维和性能调优的核心工具。通过错误日志、慢查询日志、活动会话日志的分析,开发者可以快速定位数据库异常、识别低效SQL并优化系统性能。
本文将结合 MySQL Enterprise Manager 和 pg_stat_activity 工具,系统解析数据库日志分析的完整流程,并通过实战案例展示如何从日志中挖掘价值。
一、数据库日志的核心类型与作用
日志类型 | 数据库 | 关键作用 |
---|---|---|
错误日志(Error Log) | MySQL/PostgreSQL | 记录启动失败、连接异常、崩溃恢复等关键错误 |
慢查询日志(Slow Query Log) | MySQL | 标记执行时间过长或未使用索引的SQL |
事务日志(Redo/Undo Log) | MySQL | 支持崩溃恢复与事务原子性 |
活动会话日志(pg_stat_activity) | PostgreSQL | 实时监控当前连接状态与执行语句 |
二进制日志(Binary Log) | MySQL | 用于主从复制与数据恢复 |
二、MySQL 错误日志分析与实战
1. 错误日志的开启与配置
(1)MySQL 配置文件(my.cnf
):
[mysqld]
log_error = /var/log/mysql/error.log
log_warnings = 2 # 记录警告信息
(2)验证日志路径:
SHOW VARIABLES LIKE 'log_error';
2. 常见错误日志示例与解决方案
(1)端口冲突导致服务启动失败
日志内容:
[ERROR] Could not create socket for '0.0.0.0:3306': errno: 98.
[ERROR] Port 3306 is already in use, can't start the server.
解决步骤:
# 查看占用端口的进程
lsof -i :3306
# 终止残留进程
kill -9 <PID>
(2)权限缺失导致连接失败
日志内容:
[Warning] Access denied for user 'app_user'@'%' (using password: YES)
解决步骤:
-- 检查用户权限
SELECT User, Host FROM mysql.user WHERE User = 'app_user';
-- 授予远程连接权限
CREATE USER 'app_user'@'%' IDENTIFIED BY 'StrongPassw0rd!';
GRANT ALL PRIVILEGES ON *.* TO 'app_user'@'%';
FLUSH PRIVILEGES;