Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Snappy, a fast compressor/decompressor (courtesy of Google)
Ruby C++
tree: c079b708af

Fetching latest commit…

Cannot retrieve the latest commit at this time

Failed to load latest commit information.
ext
spec
.gitignore
.rspec
Gemfile
README.md
Rakefile
libsnappy.gemspec

README.md

Snappy

A Ruby wrapper for Google's fast compressor/decompressor. From Google's own description:

Snappy is a compression/decompression library. It does not aim for maximum compression, or compatibility with any other compression library; instead, it aims for very high speeds and reasonable compression. For instance, compared to the fastest mode of zlib, Snappy is an order of magnitude faster for most inputs, but the resulting compressed files are anywhere from 20% to 100% bigger. On a single core of a Core i7 processor in 64-bit mode, Snappy compresses at about 250 MB/sec or more and decompresses at about 500 MB/sec or more.

Snappy is widely used inside Google, in everything from BigTable and MapReduce to our internal RPC systems. (Snappy has previously been referred to as “Zippy” in some presentations and the likes.)

Installation

Snappy relies on Rice (Ruby interface for C++ extensions) and assumes that you have Snappy libs installed on your system.

Once you have Snappy and Rice installed on your system, you can install the gem:

gem install snappy

Example

compressed = Snappy.compress('string to compress')
uncompressed = Snappy.uncompress(compressed)

For benchmarks and motivation behind Snappy see:

License

(MIT License) - Copyright (c) 2011 Ilya Grigorik

Something went wrong with that request. Please try again.