This is an experimental feature for raw websocket endpoint - permessage-deflate
compression for
websocket messages. Btw look at great article about websocket compression.
We consider this experimental because this websocket compression is experimental in Gorilla Websocket library that Centrifugo uses internally.
Websocket compression can reduce amount of traffic travelling over wire. But keep in mind that enabling websocket compression will result in much slower Centrifugo performance and more memory usage - depending on your message rate this can be noticeable.
To enable websocket compression for raw websocket endpoint set websocket_compression: true
in
configuration file. After this clients that support permessage-deflate will negotiate compression
with server automatically. Note that enabling compression does not mean that every connection will
use it - this depends on client support for this feature.
Another option is websocket_compression_min_size
. Default 0. This is a minimal size of message
in bytes for which we use deflate
compression when writing it to client's connection. Default
value 0
means that we will compress all messages when websocket_compression
enabled and
compression support negotiated with client.
It's also possible to control websocket compression level defined at compress/flate
By default when compression with client negotiated Centrifugo uses compression level 1 (BestSpeed).
If you want to set custom compression level use websocket_compression_level
(new in Centrifugo v1.6.4)
configuration option.