Skip to content
This repository has been archived by the owner on Nov 13, 2019. It is now read-only.

Latest commit

 

History

History
74 lines (63 loc) · 2.49 KB

Readme.md

File metadata and controls

74 lines (63 loc) · 2.49 KB

StatisticsService https://travis-ci.org/raj-saxena/StatisticsService

A scalable service that provides statistics for transactions. It takes timestamp and amount of transaction as json payload eg:

POST /transactions
{
"amount": 3.5,
"timestamp": 12890212
}

Statistics for the configured interval should be given by

GET /statistics

Output:

{
	sum: 9 //- Total sum of transaction value.
	avg: 4 //- Average amount of transaction value
	max: 5 //- Maximum transaction value
	min: 2 //- Minimum transaction value
	count: 5 // Total number of transactions
}

Requirements:

  • should scale
  • should be threadsafe
  • should be reliable over a longer period of time.
  • No database (including in-memory databases).
  • The endpoints have to execute in constant time and memory (O(1))

Run tests with ./gradlew test Run with ./gradlew bootRun



Scribbling thoughts on approach:

Need a collection that returns data of every 60 sec.

  • threadsafe, locks maybe?
  • updated on every upload
  • sum, avg, max, min, count
  • Need to maintain a data structure(cache) that maintains a sliding window of 60 sec.
  • Need to come up with right add/remove and stats calculation strategy.

When to update (add/remove/calculate)?

  • On every upload?
    • Adv: If uploads are less frequent, less writes to the cache.
    • Dis:
      • If uploads are frequent, multiple uploads in a second could cause unnecessary cycles of computation that can be batched every second.
      • Gets might read stale data if there wasn't any update in last 60 sec.
  • During get
    • Adv: Computation only done when needed.
    • Dis:
      • Collection might keep growing in absence of Gets.
      • Multiple gets in the same second will cause unnecessary recomputation.
  • Schedule update every second
    • Unnecessary calculations in absence of real update. (Dirty flags, maybe..)
  • A way in between: