Skip to content
/ flint Public

A tool to compute expected latency for various SMR protocols

License

Notifications You must be signed in to change notification settings

vonaka/flint

Repository files navigation

Flint

Go Report Card

Flint computes expected latencies for the selected set of AWS clients using different replication protocols.

Screenshot

Flint imports latency table from cloudping with the 90th percentile and a single day timeframe (see config.go). Instead of going through cloudping, flint can be launched with a provided latency table via -l command-line option. See latency_table_example.txt for an example of latency table configuration file.

Supported protocols

  • SwiftPaxos (only with fixed fast quorums)
  • Paxos
  • N2Paxos (an all-to-all variant of Paxos)
  • CURP (over N2Paxos)

Installation

go install github.com/vonaka/flint@latest

Navigation

Flint's text-based UI is powered by tview. It supports mouse events and the following hotkeys:

  • Tab: switch the focus
  • p: toggle the protocol
  • Esc: print current latency table
  • e: export latency table for the selected replicas and clients
  • i: import latency table from file
  • q: quit

About

A tool to compute expected latency for various SMR protocols

Topics

Resources

License

Stars

Watchers

Forks

Languages