Rails ожидает, что я перезапущу все изменения?

Мои взгляды работают как ожидалось; каждый раз, когда я что-то меняю, он сразу же отображается на странице. Но каждый раз, когда я вношу изменения в контроллер, модель или config, я должен перезапустить сервер, чтобы он отображался.

Я запускаю свой сервер с rails s -e development, и он устанавливает это:

  => Booting Puma
  => Rails 4.1.8 application starting in development on http://0.0.0.0:3000
  => Run `rails server -h` for more startup options
  => Notice: server is listening on all interfaces (0.0.0.0). Consider using 127.0.0.1 (--binding option)
  => Ctrl-C to shutdown server

Мой config/environments/development.rb выглядит следующим образом:

  # -*- encoding : utf-8 -*-
  Gvm::Application.configure do
  # Settings specified here will take precedence over those in config/application.rb.

  # In the development environment your application code is reloaded on
  # every request. This slows down response time but is perfect for development
  # since you don't have to restart the web server when you make code changes.
  config.cache_classes = true

  # Do not eager load code on boot.
  config.eager_load = false

  config.action_mailer.delivery_method = :smtp
  config.action_mailer.smtp_settings = {
  :address => "smtp.gmail.com",
  :port => 587,
  :domain => 'gmail.com',
  :user_name => '...',
  :password => '...',
  :authentication => 'plain',
  :enable_starttls_auto => true
  }

  config.action_mailer.default_url_options = { :host => "localhost:3000" }
  # Para debug apenas, é melhor que a linha abaixo seja adicionado apenas no ambiente de desenvolvimento
  config.action_mailer.raise_delivery_errors = true


  # Show full error reports and disable caching.
  config.consider_all_requests_local = true
  config.action_controller.perform_caching = false

  # Don't care if the mailer can't send.
  config.action_mailer.raise_delivery_errors = false

  # Print deprecation notices to the Rails logger.
  config.active_support.deprecation = :log

  # Raise an error on page load if there are pending migrations
  config.active_record.migration_error = :page_load

  # Debug mode disables concatenation and preprocessing of assets.
  # This option may cause significant delays in view rendering with a large
  # number of complex assets.
  config.assets.debug = true

  end

Любые идеи о том, почему мне все равно придется перезапустить его после каждого изменения?


Заключение (без решения):

В конце он кажется, что это ошибка рельсов и монтируемых разделов. Моя Vagrant VirtualBox VM монтирует общую папку, и при этом рельсы не могут правильно обрабатывать синхронизацию времени между гостем и хостом.

Пока у меня нет надлежащего подтверждения этой проблемы, это может объяснить первоначальный вопрос.

Ответы

Ответ 1

Добавьте эту строку в свой development.rb файл. Это работает для меня.

config.reload_classes_only_on_change = false

Примечание: С настройкой VirtualBox у нас есть очень хорошо известная проблема: rails issue track

Решение. Вам необходимо синхронизировать время между хостом и клиентом из-за некоторых изменений в Rails 4.

Ответ 2

Rails 4.1 поставляется с spring из коробки, так что это может быть ваша проблема. Запустите spring stop и после этого проверьте, остались ли какие-либо процессы spring слева ps ax | grep spring и запустите pkill -9 spring, если они есть. Перезапустите Rails и посмотрите, работает ли перезагрузка, как ожидалось.

Ответ 3

Проверьте файл development.rb, возможно,

config.cache_classes = true

В среде разработки ваш код приложения перезагружается по каждому запросу. Это замедляет время отклика, но идеально подходит для разработки, так как вам не нужно перезапускать веб-сервер при изменении кода, просто сделайте это false

  config.cache_classes = false