denke ich, dieser Effekt von der Art und Weise kommt ActionController::Reloader
geschrieben. Hier ist ActionController::Reloader#call
von 2.3.3, beachten Sie den Kommentar:
def call(env)
Dispatcher.reload_application
status, headers, body = @app.call(env)
# We do not want to call 'cleanup_application' in an ensure block
# because the returned Rack response body may lazily generate its data. This
# is for example the case if one calls
#
# render :text => lambda { ... code here which refers to application models ... }
#
# in an ActionController.
#
# Instead, we will want to cleanup the application code after the request is
# completely finished. So we wrap the body in a BodyWrapper class so that
# when the Rack handler calls #close during the end of the request, we get to
# run our cleanup code.
[status, headers, BodyWrapper.new(body)]
end
Dispatcher.reload_application
entfernt nicht automatisch geladen Konstanten, Dispatcher.cleanup_application
tut. BodyWrapper#close
mit möglichen Ausnahmen in Verstand geschrieben:
def close
@body.close if @body.respond_to?(:close)
ensure
Dispatcher.cleanup_application
end
jedoch dies nicht hilft, denn wenn @app.call
in ActionController::Reloader#call
eine Ausnahme auslöst, BodyWrapper
nicht instanziiert erhält, und Dispatcher.cleanup_application
gecallt nicht.
Stellen Sie sich folgendes Szenario vor:
- ich Änderungen in einer meiner Dateien abspeichern, die API-Aufruf beeinflusst
- ich API-Aufruf getroffen und Fehler sehen, die an dieser Stelle alle Dateien einschließlich der mit einem Fehler aren ‚t entladen
- ich einen codefix machen und schlug die gleiche API-Aufruf zu überprüfen, ob es
arbeitete
- Anruf die gleiche Art und Weise weitergeleitet wird nach wie vor zu den alten Klassen/Objekte/Module. Dies wirft gleiche Fehler und läßt wieder geladen Konstanten im Speicher
Dies geschieht nicht, wenn traditionelle Controller Fehler erhöhen, weil die von ActionController::Rescue
behandelt werden. Solche Ausnahmen treffen nicht ActionController::Reloader
.
Simplest Lösung Ausweich rescue-Klausel in API-Routing-Middleware zu setzen, eine gewisse Variation davon wäre:
def call(env)
# route API call
resuce Exception
Dispatcher.cleanup_application
raise
end
Hinweis, dass dies meine Antwort auf 3 Jahre alte Frage, und ich folgte Call-Stack von 2.3.3 . Neuere Versionen von Schienen können die Dinge anders handhaben.
Ich habe auch dieses Problem. –