Skip to main content

An all-in-one tool to assess the latency of crypto exchange APIs.

Project description

ticktracer

ticktracer is a simple Python application that allows you to trace your latency to crypto exchanges, and was developed to run on Alibaba Cloud ECS and analyze the shortest latency for exchanges hosted on Alibaba Cloud. However, any cloud provider can be used.

When the machine running ticktracer and the target exchange use the same NTP service, we can safely assume that the any clock skew between the two instances is negligible. If your instance has chronyc installed, you can verify the time synchronization status of the machine through the command chronyc sources.

Currently only websocket data feed latency can be extracted. It works by establishing a websocket connection to a crypto exchange API endpoint, decrypting the session with Wireshark, and comparing the arrival timestamp of packets with the payload timestamps provided by the exchange itself. Packet timestamps are received by libpcap from the kernel and are not generated by ticktracer itself, unlike other projects. See here for more information.

Architecture overview

Supported Exchanges

  • Binance
  • Bybit
  • OKX

Requirements

Ticktracer has been tested on the following operating systems:

  • macOS >= 14.0
  • Debian >= 12.0
  • Ubuntu >= 22.0

In addition, the following external dependencies are required:

  • wireshark or tshark >= 4.0.7
  • libssl-dev for Debian-based systems or openssl for MacOS

Installation

MacOS

Install dependencies

brew install wireshark openssl

Install ticktracer with pipx (recommended)

brew install pipx
pipx ensurepath
pipx install ticktracer

Install ticktracer with pip

Install ticktracer with pip:

python3 -m pip install ticktracer

Linux (Debian)

Install dependencies

sudo apt update && sudo apt install -y tshark libssl-dev

Install ticktracer with pipx (recommended)

sudo apt install pipx
pipx ensurepath
pipx install ticktracer

Install ticktracer with pip

python3 -m pip install ticktracer

Root permissions

Note that Wireshark requires the user to either have root privileges or to be part of the wireshark group in order to trace packets. To enable non-root access to wireshark, run the following command and select yes:

sudo dpkg-reconfigure wireshark-common

To add your user to the wireshark group, run the following command:

sudo adduser <YOUR-USER> wireshark

Create a new session in your terminal, and verify that you are part of the wireshark group with the following command:

groups

Automated environments

For automated environments, like a userdata script, use the following commands to install wireshark:

export DEBIAN_FRONTEND=noninteractive
apt update && apt install -y libssl-dev tshark

Usage

usage: ticktracer [-h] -e EXCHANGE -p PAIR -d DURATION [-i INTERFACE]

options:
  -h, --help            show this help message and exit
  -e, --exchange_id {okx,binance,bybit}
                        The exchange to connect with.
  -p, --pair PAIR       The trading pair to monitor. Look up the specific format on the exchange's API documentation.
  -d, --duration DURATION
                        Duration in seconds to monitor.
  -i, --interface INTERFACE
                        The network interface to listen on. Default is eth0 for Linux or en0 for macOS.

Example: ticktracer -e okx -p BTC/USDT -d 60

After the monitoring duration has elapsed, the script will output the latency in milliseconds across different percentiles:

Total samples taken: 11567
Latency report:
+------------+-------------------------+
| Percentile | Latency in milliseconds |
+------------+-------------------------+
|    MIN     |          3.104          |
|    25%     |          9.151          |
|    50%     |          10.401         |
|    75%     |          11.762         |
|    90%     |          13.08          |
|    95%     |          14.102         |
|    99%     |          19.474         |
|   99.9%    |          32.975         |
|    MAX     |          48.023         |
+------------+-------------------------+

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ticktracer-0.0.6.tar.gz (16.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ticktracer-0.0.6-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file ticktracer-0.0.6.tar.gz.

File metadata

  • Download URL: ticktracer-0.0.6.tar.gz
  • Upload date:
  • Size: 16.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.13.0

File hashes

Hashes for ticktracer-0.0.6.tar.gz
Algorithm Hash digest
SHA256 640d55382c7d47721aded5d008e3b9ee325a2efb94dcd8c4812b895494424011
MD5 7dbe2a7fa2c026bbea819b6c22dfeb89
BLAKE2b-256 efd0c031654d03ce10926bfd32a2144fb953c4170700b3ba4673469ec2907b59

See more details on using hashes here.

File details

Details for the file ticktracer-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: ticktracer-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 14.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.13.0

File hashes

Hashes for ticktracer-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f0fd8ea8ed9c9303d2a29cdc1a4861e79a5b36d861645d4c89976942b4028b73
MD5 ece027a2c062133ea80d6ff0dcbe6055
BLAKE2b-256 03b69f11023c715d3fcc86a54d22b9f5ed926673df084bcd86badf556c0dd82a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page