Skip to content

Latest commit

 

History

History
86 lines (59 loc) · 3.45 KB

README.md

File metadata and controls

86 lines (59 loc) · 3.45 KB

Conver Build Status

Conver is a testing tool that verifies implementations of the most common non-transactional consistency models.

It spawns client processes that perform concurrent reads and writes on the distributed store, and records their outcomes. After the execution, it builds graph entities that describe ordering and mutual visibility of operations. Finally, it uses these graph entities to check consistency semantics defined as first-order logic predicates.

By default, Conver conveniently starts distributed stores as local clusters of Docker containers, and can emulate WAN latencies through netem (without requiring admin rights).

The approach implemented in Conver has been described in this PaPoC 2016 paper.

NOTE: This is a work-in-progress Scala rewrite of the original Erlang implementation. It features a new linearizability checker, and improved consistency checks.

Getting started

Once installed JDK, Scala (with its building tool sbt) and Docker, to build Conver issue:

$ sbt compile

The following command spawns a local cluster of 3 Docker containers running ZooKeeper, and performs the consistency verification test using 10 concurrent clients that invoke 10 operations on average. Moreover, by setting the -w flag, Conver emulates wide area network settings by delaying, dropping and corrupting packets.

$ sbt "run -d zk -s 3 -c 10 -o 10 -w"

The resulting textual and graphical outputs look like the following.

Conver execution

Here are the options currently supported:

  -b, --batch  <arg>          Number of batch executions
  -d, --database  <arg>       Database (lin, reg, zk, antidote)
  -o, --mean-num-ops  <arg>   Average number of operations per client
  -c, --num-clients  <arg>    Number of clients
  -s, --num-servers  <arg>    Number of servers
  -w, --wan                   Emulate wide area network
      --help                  Show help message

Features and related work

At the moment Conver supports:

  • linearizability checking based on pseudocode from Lu et al., SOSP '15, and checking of consistency semantics describing causality and monotonicity of operations within and across sessions (e.g., monotonic writes, monotonic reads, sequential consistency, regular semantics, causal consistency --- this survey provides an overview of all these consistency semantics)
  • WAN latencies emulation

Similar projects: Jepsen, Hermitage, WatCA.
Linearizability checkers: Horn's, Lowe's, Line-up.

Authors and license

Conver has been developed at EURECOM.
License: Apache 2.0.