Подтвердить что ты не робот

Rails 4 Ошибка R14 на Heroku (превышена квота памяти)

Я получаю (видимо, общий) Ошибка 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 из инструкций из другого вопроса здесь и из Heroku здесь

Я также добавил новое дополнение Relic, и это то, что я вижу на вкладке "Мониторинг" > "Экземпляры":

За последние 7 дней: last 7 days

Последние 24 часа: last 24 hours

Я смущен, как вы можете видеть после 5/24 использования памяти, и с тех пор остался на месте, но в журналах он показывает, что память используется mem=587M(114.7%), а за последние 24 часа - в среднем 150 М, поэтому я не понимаю, что происходит. Я надеюсь, что кто-то может помочь. Спасибо.

Обновление 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 до Единорога

Это было довольно просто, следуя указаниям здесь. И это то, что сейчас выглядит, что кажется хорошим, но я подозреваю, что это было потому, что приложение было перезапущено: 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: Снижение количества работников Единорога до 2

После этого это среднее использование памяти на дино/экземпляр за последние 6 часов в соответствии с New Relic: 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, и теперь она была очень маленькой, почти устойчивой на 432 МБ и больше не получала ошибку. Так что это, похоже, устранило проблему! Я буду обновлять со временем, если это изменится.

4b9b3361

Ответ 1

Если Papertrail вызывает проблему, попробуйте другое дополнение. Я использую LogEntries без особых проблем. https://addons.heroku.com/#logging

Также попробуйте опустить рабочие процессы Unicorn, чтобы он использовал более низкую общую память. Вместо значения по умолчанию 3 (за поле/динамо) попробуйте 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

Ответ 3

Если вы используете Rails 4 с Ruby 2.1, я готов поспорить, что единственное изменение, которое вам нужно сделать, - это возврат к Ruby 2.0 обратно.

Я потратил 2 дня, чтобы понять это, и я придумал эту идею с предложениями поддержки Heroku. Я думаю, что ошибка или что-то подобное с Ruby 2.1 или Rails 4.

Обновление к апрелю 2015 года:

В то время понижение рейтинга действительно работало как решение. Но хорошо, это действительно не рекомендуемый способ решения проблем... Некоторые говорят, что модернизация для Ruby 2.2.0 с Rails 4.2 значительно снижает потребление памяти. Я бы попробовал!

Ответ 5

У меня была аналогичная проблема. Я использую Ruby 2.3.1 и Rails 4.2.6, Heroku с Unicorn. После двух параметров конфигурации в моем приложении раньше не было. Установка их с терминала с помощью следующей команды разрешила проблему для меня.

heroku config:set sensible_defaults=disabled
heroku config:set WEB_CONCURRENCY=1