Skip to content

satori-com/tcpkali

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

About

tcpkali is a high performance TCP and WebSocket load generator and sink.

tcpkali mascot

Features

  • Efficient multi-core operation (--workers); utilizes all available cores by default.
  • Allows opening massive number of connections (--connections)
  • Allows limiting an upstream and downstream of a single connection throughput (--channel-bandwidth-downstream, --channel-bandwidth-upstream or --message-rate)
  • Allows specifying the first and subsequent messages (--message, --first-message).
  • Measures response latency percentiles using HdrHistogram (--latency-marker)
  • Sends stats to StatsD/DataDog (--statsd)

Quick example: testing a web server

tcpkali -em "GET / HTTP/1.1\r\nHost: google.com\r\n\r\n" -r 10 --latency-marker "HTTP/1.1" google.com:80

Pre-requisites

During the build procedure listed below, some errors may be thrown if these pre-requisites are not met. However, installing these at runtime can still result in a problematic installation (for example, "make" does not succeed). So, better to ensure these pre-requisites are satisfied before building & installing tcpkali.

  • autoconf
  • automake
  • libtool
  • bison
  • flex
  • gcc-c++

Build & Install

test -f configure || autoreconf -iv
./configure
make
sudo make install

Build Status

Usage

Usage: tcpkali [OPTIONS] <host:port> [<host:port>...]
Where OPTIONS are:
  -h, --help                   Print this help screen, then exit
  --version                    Print version number, then exit
  -v, --verbose <level=1>      Increase (-v) or set verbosity level [0..3]
  -w, --workers <N>            Number of parallel threads to use
  --nagle {on|off}             Control Nagle algorithm (set TCP_NODELAY)
  --rcvbuf <SizeBytes>         Set TCP receive buffers (set SO_RCVBUF)
  --sndbuf <SizeBytes>         Set TCP rend buffers (set SO_SNDBUF)
  --source-ip <IP>             Use the specified IP address to connect

  --ws, --websocket            Use RFC6455 WebSocket transport
  -c, --connections <N=1>      Connections to keep open to the destinations
  --connect-rate <Rate=100>    Limit number of new connections per second
  --connect-timeout <Time=1s>  Limit time spent in a connection attempt
  --channel-lifetime <Time>    Shut down each connection after Time seconds
  --channel-bandwidth-upstream <Bandwidth>     Limit upstream bandwidth
  --channel-bandwidth-downstream <Bandwidth>   Limit downstream bandwidth
  -l, --listen-port <port>     Listen on the specified port
  --listen-mode=<mode>         What to do upon client connect, where <mode> is:
               "silent"        Do not send data, ignore received data (default)
               "active"        Actively send messages
  -T, --duration <Time=10s>    Exit after the specified amount of time

  -e, --unescape-message-args  Unescape the message data arguments
  --first-message <string>     Send this message first, once
  --first-message-file <name>  Read the first message from a file
  -m, --message <string>       Message to repeatedly send to the remote
  -f, --message-file <name>    Read message to send from a file
  -r, --message-rate <Rate>    Messages per second to send in a connection

  --latency-marker <string>    Measure latency using a per-message marker
  --latency-marker-skip <N>    Ignore the first N occurrences of a marker

  --statsd                     Enable StatsD output (default disabled)
  --statsd-host <host>         StatsD host to send data (default is localhost)
  --statsd-port <port>         StatsD port to use (default is 8125)
  --statsd-namespace <string>  Metric namespace (default is "tcpkali")

Variable units and recognized multipliers:
  <N>, <Rate>:  k (1000, as in "5k" is 5000), m (1000000)
  <SizeBytes>:  k (1024, as in "5k" is 5120), m (1024*1024)
  <Bandwidth>:  kbps, Mbps (bits per second), kBps, MBps (bytes per second)
  <Time>:       ms, s, m, h, d (milliseconds, seconds, minutes, hours, days)
  <Rate> and <Time> can be fractional values, such as 0.25.

Examples

Connect to a local web server and do nothing

tcpkali 127.0.0.1:80

Connect to a local echo server and hammer it with stream of dollars

tcpkali --message '$' localhost:echo
tcpkali -m '$' localhost:echo

Open 10000 connections to two remote servers

tcpkali --connections 10000 yahoo.com:80 google.com:80
tcpkali -c 10000 yahoo.com:80 google.com:80

Open 100 connections to itself and do nothing

tcpkali --connections 100 --listen-port 12345 127.0.0.1:12345
tcpkali -c100 -l12345 127.0.0.1:12345

Open a connection to itself and send lots of cookies

tcpkali --listen-port 12345 --message "cookies" 127.0.0.1:12345
tcpkali -l 12345 -m "cookies" 127.0.0.1:12345

Listen for incoming connections and throw away data for 3 hours

tcpkali --listen-port 12345 --duration 3h
tcpkali -l12345 -T3h

WebSocket connections

Open connection to the local WebSocket server, send hello, and wait

tcpkali --websocket --first-message "hello" 127.0.0.1:80

Open connection to the local server and send tons of empty JSON frames

tcpkali --websocket --message "{}" 127.0.0.1:80

Open connection to the local server and send a JSON frame every second

tcpkali --websocket --message "{}" --message-rate=1 127.0.0.1:80

Sysctls for high load

(for N connections, such as 50k)

kern.maxfiles=10000+2*N         # BSD
kern.maxfilesperproc=100+N      # BSD
fs.file-max=10000+2*N           # Linux
net.ipv4.tcp_max_orphans=N      # Linux

# For load-generating clients.
net.ipv4.ip_local_port_range="10000  65535"  # Linux.
net.inet.ip.portrange.hifirst=10000          # BSD/Mac.
net.inet.ip.portrange.hilast=65535           # (Enough for N < 55535)
net.ipv4.tcp_tw_reuse=1

# If using netfilter on Linux:
net.netfilter.nf_conntrack_max=N

Readings