/starbucks

2p commits exercise

Primary LanguageErlang

OTP/Erlang modelling exercise

Inspired from Starbucks Does Not Use Two-Phase Commit

Problem

Starbucks, like most other businesses is primarily interested in maximizing throughput of orders. More orders equals more revenue. As a result they use asynchronous processing. When you place your order the cashier marks a coffee cup with your order and places it into the queue. The queue is quite literally a queue of coffee cups lined up on top of the espresso machine. This queue decouples cashier and barista and allows the cashier to keep taking orders even if the barista is backed up for a moment. It allows them to deploy multiple baristas in a Competing Consumer scenario if the store gets busy.

Interaction

diagram

Messages

Customer->Cashier: new order
Cashier-->Orders: order placed
Orders->Barista: prepare
Barista-->Barista: preparing
Cashier->Customer: request payment
Barista-->Barista: toss timeout
Customer->Cashier: pay order
Cashier-->Orders: order paid
Orders->Barista: paid
Barista-->Barista: done
Note over Barista: paid & done
Barista->Customer: drink ready

Conclusion

SOA, Micro Services, Actors, Testing

Feedback

I'm @ruslanrusu on Twitter.

Your feedback is highly appreciated