gpt4 book ai didi

ruby-on-rails - Heroku 上的 Rails 4 错误 R14(超出内存配额)

转载 作者:数据小太阳 更新时间:2023-10-29 06:24:38 27 4
gpt4 key购买 nike

我得到了(显然很常见)Error R14 ,不确定它何时开始但在安装 Papertrail 附加组件后注意到了。我还添加了 oink看到别人提起后。我已经尝试了其他人在其他 SO 问题中尝试过的所有方法,但我似乎无法找到问题/内存泄漏。

Error R14 (Memory quota exceeded)
heroku/web.1: Process running mem=587M(114.7%)

当我看到这个问题时,为了临时解决这个问题,我运行了 heroku restart ,它运行了一段时间,但我想永久解决这个问题。

从我在 Papertrail 中看到的情况来看,该应用程序只是一遍又一遍地加载同一页面(主页)(而不是用户流量):

app/web.1: Completed 200 OK in 436ms (Views: 45.5ms | ActiveRecord: 386.2ms) 
app/web.1: May 25 18:14:52 5d2105e1-d799-4496-a2af-3785e78998db rails[9]: Oink Action: static_pages#home
app/web.1: May 25 18:14:52 5d2105e1-d799-4496-a2af-3785e78998db rails[9]: Memory usage: 378860 | PID: 19
app/web.1: May 25 18:14:52 5d2105e1-d799-4496-a2af-3785e78998db rails[9]: Oink Log Entry Complete
heroku/web.1: source=web.1 dyno=heroku.25566769.9d9a3da0-db4c-4b51-bc53-b69be9e43cb7 sample#memory_total=209.86MB sample#memory_rss=209.83MB sample#memory_cache=0.02MB sample#memory_swap=0.00MB sample#memory_pgpgin=59278pages sample#memory_pgpgout=5555pages

2 分钟后:

heroku/web.1: source=web.1 dyno=heroku.25566769.9d9a3da0-db4c-4b51-bc53-b69be9e43cb7 sample#memory_total=293.73MB sample#memory_rss=291.94MB sample#memory_cache=0.02MB sample#memory_swap=1.77MB sample#memory_pgpgin=80890pages sample#memory_pgpgout=6147pages `

我还根据另一个问题的说明启用了 heroku labs:enable log-runtime-metrics here来自 Heroku here

我还添加了 New Relic 附加组件,这是我在 Monitoring > Instances 选项卡中看到的:

过去 7 天: last 7 days

过去 24 小时: last 24 hours

我很困惑,你可以看到在 5/24 之后内存使用率下降并一直保持下降状态,但在日志中它显示正在使用内存 mem=587M(114.7%) 并且在最近24小时平均150M,所以我不明白发生了什么。我希望有人能帮帮忙。谢谢。

更新 1:添加了 Gemfile

#Gemfile
source 'https://rubygems.org'
ruby '2.1.1'
gem 'rails', '4.1.1'

gem 'puma', '~> 2.8.2'
gem 'turbolinks', '~> 2.2.2'
gem 'pg', '~> 0.17.1'
gem 'rack-attack', '~> 4.0.1'
gem 'memcachier'
gem 'dalli', '~> 2.7.1'
gem 'oink'
gem 'fog', '~> 1.22.0'
gem 'activeadmin', github: 'gregbell/active_admin'
gem 'dynamic_sitemaps', '~> 2.0.0'
gem 'whenever', :require => false
gem 'cancancan', '~> 1.8.0'
gem 'mini_magick', '~> 3.7.0'
gem 'carrierwave', '~> 0.10.0'
gem 'devise', '~> 3.2.4'
gem 'rolify', '~> 3.4.0'
gem 'simple_form', '~> 3.0.2'
gem 'cocoon', '~> 1.2.6'
gem 'friendly_id', '~> 5.0.3'
gem 'nokogiri', '~> 1.6.2.1'
gem 'kaminari'
gem 'impressionist', '~> 1.5.1'
gem 'validate_url'
gem 'searchkick', '~> 0.7.5'
gem 'meta-tags', '~> 2.0.0'
gem 'newrelic_rpm'


group :assets do
gem 'sass-rails', '~> 4.0.3'
gem 'bootstrap-sass', '~> 3.1.1.1'
gem 'uglifier', '~> 2.5.0'
gem 'coffee-rails', '~> 4.0.1'
gem 'asset_sync'
#gem 'jquery-turbolinks'
gem 'jquery-rails'
gem 'jbuilder', '~> 2.0.7'
end

group :production do
gem 'rails_12factor'
end

更新 2:将服务器从 Puma 更改为 Unicorn

非常简单,按照说明操作 here .这就是现在的样子,看起来不错,但我怀疑是因为应用程序重新启动了: last30mins

# after heroku restart
heroku/web.1: source=web.1 dyno=heroku.25566769.3770e52a-ddf3-485a-a88a-ac4fd54ab640 sample#memory_total=123.62MB

# after 4 minutes
heroku/web.1: source=web.1 dyno=heroku.25566769.3770e52a-ddf3-485a-a88a-ac4fd54ab640 sample#memory_total=276.48MB

更新 3:将 unicorn worker 的数量减少到 2

之后,根据 New Relic,这是过去 6 小时每个 dyno/实例的平均内存使用量: lasy6hoursafter

PaperTrain 中的输出(也尝试了 LogEntries)是这样的:

app/web.1: May 26 19:54:08 21ae35ee-5656-4254-9f12-5dc6bb59efa1 rails[6]: Memory usage: 426076 | PID: 6
app/web.1: May 26 19:54:08 21ae35ee-5656-4254-9f12-5dc6bb59efa1 rails[6]: Oink Log Entry Complete
heroku/web.1: source=web.1 dyno=heroku.25566769.21ae35ee-5656-4254-9f12-5dc6bb59efa1 sample#load_avg_1m=0.00 sample#load_avg_5m=0.00 sample#load_avg_15m=0.00
heroku/web.1: source=web.1 dyno=heroku.25566769.21ae35ee-5656-4254-9f12-5dc6bb59efa1 sample#memory_total=431.99MB sample#memory_rss=406.85MB sample#memory_cache=0.10MB sample#memory_swap=25.04MB sample#memory_pgpgin=198612pages sample#memory_pgpgout=94432pages

我检查了日志,1 小时后我收到了 R14 错误,现在它几乎没有上升,几乎稳定在 432MB,并且再也没有收到错误。所以这似乎解决了问题!如果有变化,我会及时更新。

最佳答案

如果 Papertrail 导致问题,请尝试其他插件。我一直在使用 LogEntries,没有太大问题。 https://addons.heroku.com/#logging

同时尝试降低您的 Unicorn 工作进程,以便它使用较低的总内存。而不是默认的 3(每个盒子/dyno),尝试 2。

https://devcenter.heroku.com/articles/rails-unicorn#unicorn-worker-processes

您还可以在您的应用上运行内存分析器:

http://timetobleed.com/memprof-a-ruby-level-memory-profiler/

https://www.ruby-toolbox.com/search?utf8=%E2%9C%93&q=profile

关于ruby-on-rails - Heroku 上的 Rails 4 错误 R14(超出内存配额),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23858694/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com