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