MySQL不直接提供访问日志功能,需由应用层主动写入专用日志表,设计时应包含id、created_at、ip、user_id、path、method、status_code等必选字段,辅以异步写入、合理索引、分区归档等策略保障性能与可维护性。

MySQL 本身不直接提供类似 Web 服务器的“访问日志”(access log)功能,但可以通过应用层主动写入 + 合理的表结构设计,实现对用户操作、接口调用或关键查询的访问行为记录。核心思路是:由业务代码在关键路径中插入日志数据到专用日志表,而非依赖 MySQL 自带的 general_log(性能差、难过滤、不推荐生产使用)。
日志表需兼顾可读性、查询效率与存储成本,避免过度冗余,也别遗漏关键上下文:
以下是一个轻量、可扩展的日志表结构:
Modoer 是一款以本地分享,多功能的点评网站管理系统。采用 PHP+MYSQL 开发设计,开放全部源代码。因具有非凡的访问速度和卓越的负载能力而深受国内外朋友的喜爱。在升级前一定要备份好自己的原版本,特别是自己设计了模板和修改了代码的用户。Modoer多功能点评系统 v1.2.5 Build 20111220更新列表修正 安全漏洞和安全隐患增加 后台登陆和SQL错误记录日志修复 若干小BUG
0
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 + <code>DELETE,或导出为 CSV 存对象存储
以上就是如何使用mysql实现访问日志记录_mysql访问日志表设计的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号