Performance benchmark
Read+Write
TPS
1 M
Latency
34 ms p(99)
Cost
$25.01
per month / per 1K TPS
Read Only
TPS
750 K
Latency
23 ms p(99)
Write Only
TPS
250K
Latency
52 ms p(99)
Configuration
Read / Write Allocation: 75% / 25%
Data Unit Size: 550 bytes
Testbed: 4 Gatling instances, 8 cores, 15 minutes progressive throughput
App: Akka 2023.10, 240K entities, event sourced log, source code
Infrastructure:
25 EC2 m5.8xlarge ($0.9680 / hr)
1 EKS cluster ($0.10 / hr)
8 RDS db.r6g.2xlarge ($354 / mo 1-yr full upfront)
8 SSD 100 GB io2 5K IOPS ($512.50 / mo)
Total Monthly Cost: $25,011.20
Definitions
TPS: # of transactional data units processed (read & write) / second
Latency: round trip HTTP request-response time measured during peak TPS
Cost: Total reserved instance costs for a 31 day month ratioed against 1K TPS
This was a sample test to demonstrate that 1,000,000 req/s of a mixed load (75% reads, 25% writes) was possible with Akka whose events are persisted to a Postgres database. This application simulates a digital twin solution, where a single Akka actor represented an IOT device that had to persist 550 bytes of information on each update. Every read request also returns 550 bytes of data. 240K entities were created and all of their state changes were persisted against a single event log RDS database instance.
Ultimately, in this configuration, customers would pay $25.09 / month per each 1 thousand TPS performance.