Gem Version Build Status

Rack::Compress

Rack::Compress compresses Rack responses using Google's Brotli and Facebook's Zstandard compression algorithms.

Those generally compresses better than gzip for the same CPU cost. Brotli is supported by Chrome, Firefox, IE and Opera, while Zstandard (aka. Zstd) began making its way into major browsers and as of today it's available on Chrome behind feature flags, see the caniuse page.

Use

Install gem:

gem install rack-compress

Requiring 'rack/compress' will autoload Rack::compress module. The following example shows what a simple rackup (config.ru) file might look like:

require 'rack'
require 'rack/compress'

use Rack::Compress

run theapp

Note that it is up to the browser or the HTTP client to choose the compression algorithm. This occurs via the accept-encoding header. Rack::Compress always gives priority to zstd when the client supports it, since it should perform better than Brotli according to benchmarking.

It's possible to also customize the compression levels for each algorithm:

use Rack::Compress, {
  levels: {
    brotli: 11, # must be between 0 and 11
    zstd: 19 # must be between 1 and 19
  }
}

In case you want to better control which MIME types get compressed:

use Rack::Compress, { include: [
  'text/html',
  'text/css',
  'application/javascript',
] }

The above will compress all those MIME types and not any other.

Testing

To run the entire test suite, run

rake test

Acknowledgements

Thanks to Marco Costa for the original gem form which this one was forked from.