ActiveRecord Query Trace 技术文档
1. 安装指南
1.1 环境要求
- Ruby 版本 >= 2.7
- Rails 版本 6.0、6.1 或 7.0
1.2 安装步骤
-
在
Gemfile中添加以下内容:group :development do gem 'active_record_query_trace' end -
创建一个初始化文件,例如
config/initializers/active_record_query_trace.rb,并在其中启用该 gem。如果需要自定义 gem 的行为,可以在初始化文件中添加以下配置选项:if Rails.env.development? ActiveRecordQueryTrace.enabled = true # 可选:其他 gem 配置选项可以在这里添加 end -
重启 Rails 开发服务器。
2. 项目的使用说明
2.1 启用查询追踪
在开发环境中,启用 active_record_query_trace 后,每次执行数据库查询时,日志中都会显示查询的调用栈信息。这有助于追踪查询在应用程序中的执行位置,特别是在性能优化或大型应用程序中进行更改时。
2.2 日志示例
启用后,日志将显示如下内容:
D, [2019-03-03T19:50:41.061115 #25560] DEBUG -- : User Load (0.1ms) SELECT "users".* FROM "users"
D, [2019-03-03T19:50:41.062492 #25560] DEBUG -- : Query Trace:
app/models/concerns/is_active.rb:11:in `active?'
app/models/user.rb:67:in `active?'
app/decorators/concerns/status_methods.rb:42:in `colored_status'
app/views/shared/companies/_user.html.slim:28:in `block in _app_views_users_html_slim___2427456029761612502_70304705622200'
app/views/shared/companies/_user.html.slim:27:in `_app_views_users_html_slim___2427456029761612502_70304705622200'
3. 项目 API 使用文档
3.1 配置选项
3.1.1 调用栈级别
有三种调试级别可供选择:
:app- 仅包含应用程序的调用栈(位于Rails.root目录下的文件);:rails- 包含除应用程序之外的所有调用栈(所有不在Rails.root目录下的文件);:full- 完整的调用栈(包含所有文件),适用于调试 gem。
ActiveRecordQueryTrace.level = :app # 默认值
如果需要更多控制,可以使用 :custom 级别并提供自定义的调用栈清理器:
ActiveRecordQueryTrace.level = :custom
require "rails/backtrace_cleaner"
ActiveRecordQueryTrace.backtrace_cleaner = Rails::BacktraceCleaner.new.tap do |bc|
bc.remove_filters!
bc.remove_silencers!
bc.add_silencer { |line| line =~ /\b(active_record_query_trace|active_support|active_record|another_gem)\b/ }
end
3.1.2 查询类型
可以选择仅为读取或写入操作显示调用栈:
:all- 显示所有查询的调用栈;:read- 仅显示数据库读取操作(SELECT)的调用栈;:write- 仅显示数据库写入操作(INSERT, UPDATE, DELETE)的调用栈。
ActiveRecordQueryTrace.query_type = :all # 默认值
3.1.3 抑制数据库读取查询日志
如果设置为 true,此选项将抑制所有由数据库读取操作(SELECT)生成的日志行,仅保留由数据库写入操作生成的日志行。注意,整个日志行都会被抑制,而不仅仅是调用栈。
ActiveRecordQueryTrace.suppress_logging_of_db_reads = false # 默认值
3.1.4 忽略缓存查询
默认情况下,每次查询都会记录调用栈,即使是不实际访问数据库的缓存查询。你可以选择不为缓存查询打印调用栈:
ActiveRecordQueryTrace.ignore_cached_queries = true # 默认值为 false
3.1.5 限制调用栈行数
如果应用程序较大,你可能希望限制每次查询显示的调用栈行数。如果将 level 设置为 :full,你可能希望将 lines 设置为 0,以便查看完整的调用栈。
ActiveRecordQueryTrace.lines = 10 # 默认值为 5。设置为 0 将包含完整的调用栈。
3.1.6 调用栈颜色
可以为调用栈输出着色:
ActiveRecordQueryTrace.colorize = false # 无颜色(默认)
ActiveRecordQueryTrace.colorize = :light_purple # 使用特定颜色着色
有效颜色包括::black, :red, :green, :brown, :blue, :purple, :cyan, :gray, :dark_gray, :light_red, :light_green, :yellow, :light_blue, :light_purple, :light_cyan, :white。
4. 项目安装方式
4.1 通过 Gemfile 安装
在 Gemfile 中添加以下内容:
group :development do
gem 'active_record_query_trace'
end
4.2 创建初始化文件
在 config/initializers/ 目录下创建一个初始化文件,例如 active_record_query_trace.rb,并在其中启用 gem:
if Rails.env.development?
ActiveRecordQueryTrace.enabled = true
# 可选:其他 gem 配置选项可以在这里添加
end
4.3 重启服务器
完成上述步骤后,重启 Rails 开发服务器以使配置生效。
结语
通过 active_record_query_trace,你可以轻松追踪应用程序中的数据库查询,帮助你在性能优化和代码修改时快速定位问题。希望本文档能帮助你更好地理解和使用该工具。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112