Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Detect and show a maintenance page
Pull request Compare This branch is 32 commits ahead, 1 commit behind ddollar:master.

version 2.0.1

this includes the correct octet-size of the maintenance file length.
latest commit 253c8e8609
@tilsammans authored



Rack::Maintenance is a simple Rack middleware to detect the existence of a maintenance page and display that instead of incoming requests.


sudo gem install rack-maintenance

Installation with Bundler

In Gemfile:

gem 'rack-maintenance'

and then run `bundle`.


# html maintenance response
config.middleware.use 'Rack::Maintenance',
  :file => Rails.root.join('public', 'maintenance.html'),
  :env  => 'MAINTENANCE'

# json maintenance response
# it's up to you to provide a valid JSON file!
config.middleware.use 'Rack::Maintenance',
  :file => Rails.root.join('public', 'maintenance.json'),
  :env  => 'MAINTENANCE'

If :env is specified, all requests will be shown the maintenance page if the environment variable is set.

If :env is not specified, the maintenance page will be shown if it exists.

# Leave some paths enabled while site is down
# You'll usually want to exclude /assets if you'd like to retain CSS.
# It also works for allowing access to admin while the rest is in maintenance mode.
config.middleware.use 'Rack::Maintenance',
  :file => Rails.root.join('public', 'maintenance.html'),
  :without => /\A\/assets/

Note on Patches/Pull Requests

  • Fork the project.

  • Make your feature addition or bug fix in a branch.

  • Add tests for it.

  • Commit, do not mess with Rakefile or VERSION (do that in a separate commit if you want a local version)

  • Push your branch.

  • Send me a pull request.

Space Babies

We create internet.


BSD. See LICENSE for details.

Something went wrong with that request. Please try again.