Skip to content

WebSocket Per-Message Compress Extension statistics calculator

Notifications You must be signed in to change notification settings

zaphoyd/ws-pmce-stats

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 

Repository files navigation

WebSocket Per-Message Compress Extension statistics calculator
==============================================================

ws-pmce-stats is a program that performs some basic calculations to 
determine the speed, memory usage, and compression effectiveness of
various input data sets and compression settings.

In particular, it can be used to tune the negotiation parameters of
WebSocket permessage compression extensions based on a set of input
data that roughly matches the types of messages that will be sent
by the application in question.

Build
=====
ws-pmce-stats is written in C++. Its only dependencies are the C++11
standard library and the zlib headers and library. Build examples
on several common platforms follow.

Mac OS X / XCode (clang/llvm)
clang++ -std=c++0x -stdlib=libc++ -o ws-pmce-stats ws-pmce-stats.cpp -lz

Linux / GCC
g++ -std=c++0x -o ws-pmce-stats ws-pmce-stats.cpp -lz

Usage
=====
This information can also be printed by running `ws-pmce-stats --help`

Usage: ws-pmce-stats [parameter1=val1, [parameter2=val2]]

Pass data in via standard input. ws-pmce-stats will simulate a WebSocket
connection using the parameters defined below. One line of input
represents one websocket message. Stats about the speed, memory usage,
and compression ratio will be printed at the end.

Optional parameters: (usage key=val, in any combination, in any order)
  server: [true,false]; Default true; 
    Simulate a server (vs client). Affects frame overhead stats.

  sending: [true,false]; Default true; 
    Simulate sending (vs receiving). Affects memory usage stats.

  context_takeover: [true,false]; Default true; 
    Reuse compression context between messages. A value of false is
    equivilent to negotiating the permessage-deflate setting of 
    *_no_context_takeover. If this value is true a separate compression
    context must be maintained for each connection. 

  speed_level: [0...9]; Default 6; 
    A tuning parameter that trades compression quality vs CPU usage.
    A value of 0 indicates no compression at all. This value may be
    unilaterally set by a WebSocket endpoint without negotiation.

  window_bits: [8-15]; Default 15; 
    Base 2 logarithm of the size to use for the LZ77 sliding window.
    Higher values use more memory but provide better compression. This
    value must be negotiated. A stream compressed with n bits can be
    decompressed only by an endpoint that uses at least that many. Not
    all WebSocket endpoints will support negotiating this parameter.

  memory_level: [1-9]; Default 8; 
    A tuning parameter that trades compression quality vs memory usage.
    A value of 1 indicates lowest memory usage but worst compression. A
    value of 9 incidates most memory usage but best compression. This
    parameter may be set unilaterally without negotiation.

Examples
========

Run with default settings on JSON Chat example data set
`cat datasets/jsonchat.txt | ./ws-pmce-stats`

Change one default setting
`cat datasets/jsonchat.txt | ./ws-pmce-stats context_takeover=false`

Change all default settings
`cat datasets/jsonchat.txt | ./ws-pmce-stats server=false sending=false context_takeover=false windowbits=8 memory_level=1 speed_level=1`

Author & License
================

Written by Peter Thorson (websocket@zaphoyd.com)

BSD Licensed (see source code for full license details)

About

WebSocket Per-Message Compress Extension statistics calculator

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages