我在 Rails 4.2.1 之上使用 Grape 为我们的应用程序提供 API。
但是当我今天检查 Newrelic 的性能时我发现RackApp Proc#call
and Grape API::Root#call
占用了大量的时间。 (见截图)
然后我尝试记录中间件消耗的时间rack_timer
并发现ActionDispatch::Routing::RouteSet
占用了大部分时间:
Rack Timer (Application Action) -- ActionDispatch::Routing::RouteSet: 67.12579727172852 ms
Rack Timer (Application Action) -- ActionDispatch::Routing::RouteSet: 101.51457786560059 ms
Rack Timer (Application Action) -- ActionDispatch::Routing::RouteSet: 84.18059349060059 ms
Rack Timer (Application Action) -- ActionDispatch::Routing::RouteSet: 1236.2565994262695 ms
Rack Timer (Application Action) -- ActionDispatch::Routing::RouteSet: 8.124351501464844 ms
Rack Timer (Application Action) -- ActionDispatch::Routing::RouteSet: 55.65309524536133 ms
甚至有需要 500ms - 1000ms 的情况ActionDispatch::Routing::RouteSet
。我怎样才能找到这个问题,我怎样才能知道我在 Rails 路线中做错了什么?
非常感谢您的帮助。
对我来说,事实证明 Newrelic ruby 代理不能与 Rocket_pants(我用来构建 API 端点的 gem)一起使用。
有一个第三方 gem 'rocket_pants-rpm' 可以解决这个问题,但是原来的 gem 从 newrelic_rpm 版本 3.9+ 开始停止工作,要解决这个问题,请尝试使用分叉版本:https://github.com/SpartaSales/rocket_pants-rpm https://github.com/SpartaSales/rocket_pants-rpm
这就是添加这个 gem 后 newrelic 报告对我来说的样子。
newrelic 请求时间百分比 https://i.stack.imgur.com/EVRvj.png
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)