MySQL不直接提供访问日志功能,需由应用层主动写入专用日志表,设计时应包含id、created_at、ip、user_id、path、method、status_code等必选字段,辅以异步写入、合理索引、分区归档等策略保障性能与可维护性。
MySQL 本身不直接提供类似 Web 服务器的“访问日志”(access log)功能,但可以通过应用层主动写入 + 合理的表结构设计,实现对用户操作、接口调用或关键查询的访问行为记录。核心思路是:由业务代码在关键路径中插入日志数据到专用日志表,而非依赖 MySQL 自带的 general_log(性能差、难过滤、不推荐生产使用)。
日志表需兼顾可读性、查询效率与存储成本,避免过度冗余,也别遗漏关键上下文:
以下是一个轻量、可扩展的日志表结构:
CREATE TABLE `access_log` ( `id` BIGINT UNSIGNED NOT NULL AUTO_INCREMENT,`created_at` DATETIME(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3), `ip` VARCHAR(45) NOT NULL DEFAULT '', `user_id` BIGINT UNSIGNED NULL COMMENT '登录用户ID,未登录则为NULL', `path` VARCHAR(255) NOT NULL, `method` ENUM('GET','POST','PUT','DELETE','PATCH') NOT NULL, `status_code` SMALLINT NOT NULL DEFAULT 200, `duration_ms` INT UNSIGNED NULL COMMENT '处理耗时(毫秒)', `user_agent` VARCHAR(512) NULL, `referer` VARCHAR(512) NULL, `request_id` VARCHAR(64) NULL, `params_summary` VARCHAR(512) NULL, PRIMARY KEY (`id`), INDEX `idx_created_at` (`created_at`) COMMENT '按时间范围查询最常用', INDEX `idx_user_id` (`user_id`) COMMENT '查某用户行为', INDEX `idx_path_method` (`path`, `method`) COMMENT '查某接口调用频次', INDEX `idx_ip` (`ip`) COMMENT '查异常IP' ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
不要在每个请求中同步执行 INSERT(会拖慢响应),推荐异步写入或批量落库:
日志表增长快,需配套运维策略:
SELECT COUNT(*) FROM access_log WHERE created_at > DATE_SUB(NOW(), INTERVAL 7 DAY) 统计周调用量INSERT INTO archive_access_log SELECT * FROM access_log WHERE created_at + DELETE,或导出为 CSV 存对象存储