最轻量方式是在业务层用 time.Now() + defer 封装 Query/Exec 等调用,避免拼接完整 SQL 防泄密;sqlx 可包装方法加计时,gorm v2+ 应实现 logger.Interface 的 Trace 方法获取真实耗时。

如何在Golang中监控数据库查询性能 Go语言SQL执行时间日志

怎么给 database/sql 查询加执行时间日志

Go 标准库的 database/sql 本身不暴露查询耗时,得靠 sql.Driver 层或中间件式包装。最轻量且可控的方式是用 sql.Register 注册一个带计时逻辑的驱动代理,或者更推荐:在业务层统一用 sql.Connsql.Tx 执行前打点。

实操建议:

sqlxgorm 里怎么拿到真实执行耗时

第三方库通常把底层 database/sql 调用包得更深,直接 hook driver.Stmt 不现实。它们一般提供钩子(hook)或可插拔的日志器接口。

实操建议:

为什么 SHOW PROCESSLIST 看到的 Time 和应用日志差很多

MySQL 的 Time 列表示线程空闲或等待锁的时间,不是 SQL 执行耗时;而 Go 应用日志里测的是从 db.Query 调用到 rows.Close() 或结果解析完成的整个周期,两者根本不在同一维度。

常见错误现象:

监控上线后必须关掉的三个默认行为

本地调试时开着的耗时日志,上线不关会吃 CPU、撑大日志体积、暴露 SQL 结构,甚至拖慢 DB 连接复用效率。

实操建议:

真正难的不是记录时间,而是区分清楚:这是网络延迟?SQL 执行慢?Go 层反序列化慢?还是连接池配置太小导致排队?每种情况对应的排查路径和修复方式完全不同,别让日志格式统一就误以为原因也统一。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。