Commit Latency vs Throughput
Commit Latency vs Throughput
Analysis of how commit latency scales with achieved throughput.
Values shown as mean ± standard deviation across seeds.
num_tables = 1
| Throughput (c/s) | Success Rate (%) | P50 Latency (s) | P95 Latency (s) | P99 Latency (s) | Mean Retries |
|---|
| 0.2 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.01 | 0.52 ± 0.03 | 1.0 |
| 0.4 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.47 ± 0.01 | 0.58 ± 0.04 | 1.1 |
| 0.8 ± 0.0 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.52 ± 0.01 | 0.67 ± 0.02 | 1.1 |
| 1.6 ± 0.0 | 100.0 ± 0.0 | 0.34 ± 0.00 | 0.66 ± 0.01 | 0.89 ± 0.03 | 1.4 |
| 2.1 ± 0.0 | 100.0 ± 0.0 | 0.35 ± 0.00 | 0.71 ± 0.01 | 0.98 ± 0.02 | 1.5 |
| 2.8 ± 0.0 | 99.9 ± 0.0 | 0.37 ± 0.00 | 0.86 ± 0.02 | 1.26 ± 0.05 | 1.8 |
| 4.0 ± 0.0 | 98.5 ± 0.2 | 0.47 ± 0.00 | 1.26 ± 0.02 | 1.71 ± 0.02 | 2.6 |
| 6.0 ± 0.0 | 73.8 ± 0.3 | 0.78 ± 0.00 | 1.71 ± 0.01 | 1.88 ± 0.01 | 4.5 |
| 6.9 ± 0.0 | 42.1 ± 0.3 | 0.91 ± 0.01 | 1.75 ± 0.00 | 1.89 ± 0.00 | 5.1 |
| 7.8 ± 0.0 | 19.0 ± 0.1 | 0.97 ± 0.01 | 1.75 ± 0.00 | 1.89 ± 0.00 | 5.3 |
num_tables = 2
| Throughput (c/s) | Success Rate (%) | P50 Latency (s) | P95 Latency (s) | P99 Latency (s) | Mean Retries |
|---|
| 0.2 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.42 ± 0.01 | 0.46 ± 0.01 | 1.0 |
| 0.4 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.01 | 0.52 ± 0.03 | 1.1 |
| 0.8 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.46 ± 0.02 | 0.57 ± 0.01 | 1.1 |
| 1.6 ± 0.0 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.52 ± 0.01 | 0.66 ± 0.01 | 1.3 |
| 2.1 ± 0.0 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.55 ± 0.00 | 0.71 ± 0.01 | 1.4 |
| 2.7 ± 0.0 | 100.0 ± 0.0 | 0.34 ± 0.00 | 0.60 ± 0.01 | 0.79 ± 0.02 | 1.5 |
| 4.1 ± 0.0 | 100.0 ± 0.0 | 0.35 ± 0.00 | 0.71 ± 0.01 | 0.99 ± 0.03 | 1.8 |
| 8.1 ± 0.0 | 98.2 ± 0.1 | 0.48 ± 0.00 | 1.25 ± 0.01 | 1.63 ± 0.01 | 3.1 |
| 11.9 ± 0.0 | 72.8 ± 0.3 | 0.75 ± 0.00 | 1.60 ± 0.00 | 1.77 ± 0.00 | 5.0 |
| 14.0 ± 0.0 | 34.1 ± 0.1 | 0.87 ± 0.01 | 1.62 ± 0.00 | 1.77 ± 0.00 | 5.6 |
num_tables = 5
| Throughput (c/s) | Success Rate (%) | P50 Latency (s) | P95 Latency (s) | P99 Latency (s) | Mean Retries |
|---|
| 0.2 ± 0.0 | 100.0 ± 0.0 | 0.31 ± 0.00 | 0.41 ± 0.01 | 0.46 ± 0.02 | 1.0 |
| 0.4 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.41 ± 0.01 | 0.48 ± 0.01 | 1.1 |
| 0.8 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.01 | 0.52 ± 0.01 | 1.1 |
| 1.7 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.45 ± 0.00 | 0.56 ± 0.01 | 1.2 |
| 2.1 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.47 ± 0.01 | 0.58 ± 0.01 | 1.3 |
| 2.7 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.49 ± 0.00 | 0.61 ± 0.01 | 1.4 |
| 4.1 ± 0.0 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.53 ± 0.00 | 0.68 ± 0.01 | 1.6 |
| 8.2 ± 0.1 | 100.0 ± 0.0 | 0.34 ± 0.00 | 0.64 ± 0.00 | 0.87 ± 0.01 | 2.1 |
| 16.3 ± 0.1 | 99.6 ± 0.1 | 0.42 ± 0.00 | 1.00 ± 0.01 | 1.42 ± 0.02 | 3.0 |
| 29.8 ± 0.1 | 72.5 ± 0.2 | 0.75 ± 0.00 | 1.57 ± 0.00 | 1.73 ± 0.00 | 5.2 |
num_tables = 10
| Throughput (c/s) | Success Rate (%) | P50 Latency (s) | P95 Latency (s) | P99 Latency (s) | Mean Retries |
|---|
| 0.2 ± 0.0 | 100.0 ± 0.0 | 0.31 ± 0.00 | 0.40 ± 0.01 | 0.45 ± 0.02 | 1.0 |
| 0.4 ± 0.0 | 100.0 ± 0.0 | 0.31 ± 0.00 | 0.41 ± 0.00 | 0.47 ± 0.01 | 1.1 |
| 0.8 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.42 ± 0.00 | 0.49 ± 0.01 | 1.1 |
| 1.6 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.00 | 0.52 ± 0.00 | 1.2 |
| 2.0 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.00 | 0.53 ± 0.00 | 1.3 |
| 2.7 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.45 ± 0.01 | 0.54 ± 0.01 | 1.4 |
| 4.1 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.47 ± 0.00 | 0.58 ± 0.01 | 1.5 |
| 8.2 ± 0.0 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.53 ± 0.00 | 0.67 ± 0.01 | 1.9 |
| 16.4 ± 0.0 | 100.0 ± 0.0 | 0.34 ± 0.00 | 0.64 ± 0.01 | 0.87 ± 0.01 | 2.3 |
| 40.2 ± 0.0 | 98.0 ± 0.0 | 0.48 ± 0.00 | 1.22 ± 0.01 | 1.59 ± 0.01 | 3.6 |
num_tables = 20
| Throughput (c/s) | Success Rate (%) | P50 Latency (s) | P95 Latency (s) | P99 Latency (s) | Mean Retries |
|---|
| 0.2 ± 0.0 | 100.0 ± 0.0 | 0.29 ± 0.01 | 0.40 ± 0.01 | 0.45 ± 0.00 | 1.0 |
| 0.4 ± 0.0 | 100.0 ± 0.0 | 0.31 ± 0.00 | 0.41 ± 0.00 | 0.45 ± 0.01 | 1.1 |
| 0.8 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.41 ± 0.00 | 0.48 ± 0.01 | 1.1 |
| 1.6 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.42 ± 0.00 | 0.48 ± 0.01 | 1.2 |
| 2.1 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.42 ± 0.00 | 0.51 ± 0.01 | 1.3 |
| 2.7 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.00 | 0.51 ± 0.01 | 1.4 |
| 4.1 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.44 ± 0.00 | 0.53 ± 0.00 | 1.5 |
| 8.2 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.47 ± 0.00 | 0.58 ± 0.01 | 1.8 |
| 16.4 ± 0.0 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.53 ± 0.00 | 0.67 ± 0.00 | 2.1 |
| 41.0 ± 0.1 | 100.0 ± 0.0 | 0.35 ± 0.00 | 0.72 ± 0.00 | 1.00 ± 0.00 | 2.5 |
num_tables = 50
| Throughput (c/s) | Success Rate (%) | P50 Latency (s) | P95 Latency (s) | P99 Latency (s) | Mean Retries |
|---|
| 0.2 ± 0.0 | 100.0 ± 0.0 | 0.22 ± 0.02 | 0.39 ± 0.01 | 0.43 ± 0.01 | 1.0 |
| 0.4 ± 0.0 | 100.0 ± 0.0 | 0.29 ± 0.00 | 0.40 ± 0.01 | 0.45 ± 0.01 | 1.0 |
| 0.8 ± 0.0 | 100.0 ± 0.0 | 0.31 ± 0.00 | 0.40 ± 0.01 | 0.46 ± 0.01 | 1.1 |
| 1.6 ± 0.0 | 100.0 ± 0.0 | 0.31 ± 0.00 | 0.41 ± 0.00 | 0.47 ± 0.00 | 1.2 |
| 2.0 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.41 ± 0.00 | 0.48 ± 0.00 | 1.3 |
| 2.7 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.42 ± 0.00 | 0.48 ± 0.01 | 1.3 |
| 4.1 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.42 ± 0.00 | 0.49 ± 0.00 | 1.5 |
| 8.2 ± 0.0 | 100.0 ± 0.0 | 0.32 ± 0.00 | 0.43 ± 0.00 | 0.52 ± 0.00 | 1.8 |
| 16.4 ± 0.1 | 100.0 ± 0.0 | 0.32 | 0.46 ± 0.00 | 0.56 ± 0.00 | 2.0 |
| 41.0 ± 0.1 | 100.0 ± 0.0 | 0.33 ± 0.00 | 0.53 ± 0.00 | 0.68 ± 0.00 | 2.2 |
Notes
- Latencies reported in seconds (converted from milliseconds)
- Values shown as mean ± standard deviation across multiple seeds
- Throughput = commits per second during steady-state window
- Success rate = percentage of transactions that committed successfully
- Mean retries = average number of retry attempts per committed transaction