X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/52395b3cdf4d3cfae95730158edeeccf3d062a8e..1abb7bfa56318b293c7a57dd094961b241e0673d:/config/initializers/memory_limits.rb?ds=sidebyside diff --git a/config/initializers/memory_limits.rb b/config/initializers/memory_limits.rb index 6f553aff6..ce518269f 100644 --- a/config/initializers/memory_limits.rb +++ b/config/initializers/memory_limits.rb @@ -1,11 +1,11 @@ # Setup any specified hard limit on the virtual size of the process -if APP_CONFIG.include?('hard_memory_limit') and Process.const_defined?(:RLIMIT_AS) - Process.setrlimit Process::RLIMIT_AS, APP_CONFIG['hard_memory_limit']*1024*1024, Process::RLIM_INFINITY +if defined?(HARD_MEMORY_LIMIT) and defined?(PhusionPassenger) and Process.const_defined?(:RLIMIT_AS) + Process.setrlimit Process::RLIMIT_AS, HARD_MEMORY_LIMIT*1024*1024, Process::RLIM_INFINITY end # If we're running under passenger and a soft memory limit is # configured then setup some rack middleware to police the limit -if APP_CONFIG.include?('soft_memory_limit') and defined?(PhusionPassenger) +if defined?(SOFT_MEMORY_LIMIT) and defined?(PhusionPassenger) # Define some rack middleware to police the soft memory limit class MemoryLimit def initialize(app) @@ -17,8 +17,8 @@ if APP_CONFIG.include?('soft_memory_limit') and defined?(PhusionPassenger) status, headers, body = @app.call(env) # Restart if we've hit our memory limit - if resident_size > APP_CONFIG['soft_memory_limit'] - Process.kill("USR1", 0) + if resident_size > SOFT_MEMORY_LIMIT + Process.kill("USR1", Process.pid) end # Return the result of this request