0.0
Low commit activity in last 3 years
Rack::Compress enables Zstd and Brotli compression on HTTP responses
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 5.6
~> 12, >= 12.3.3
~> 3.12

Runtime

>= 0.1.7
>= 1.4
>= 1.5
 Project Readme

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.