Decoupled, Immutable REST APIs With Kafka Streams

Bobby Calderwood (14.Jul.2018 at 09:15, 1 hr )
Talk at Mid-Atlantic Developer Conference (English - US)

Rating: 5 of 5

Have you ever hit a wall with REST? Does modeling your problem domain into CRUD-able entities feel like fitting a square peg into a round hole? Perhaps instead of modeling our services like little databases, we should instead model them like reactors to event streams.

REST APIs are great, but their typical implementation tightly couples various concerns which would be better separated:

* Reads (perception) from writes (action)
* Current state from historical narrative
* Business logic from HTTP design from operational concerns like metrics and monitoring

Commander is a pattern for writing REST APIs that de-couples these concerns, thereby alleviating common frustrations with CRUD-flavored REST. This pattern imposes a clear separation of action from perception and uses Kafka and Kafka Streams to separate business logic from HTTP concerns, all while preserving the historical narrative of the entire event stream.

In this talk, I'll discuss the benefits and tradeoffs of this approach, and demonstrate my implementation using Clojure in the HTTP layer, and using Java with the new Kafka Streams library in the event stream processing layer.

Who are you?

Claim talk

Talk claims have been moved to the new Joind.in site.

Please login to the new site to claim your talk

Want to comment on this talk? Log in or create a new account or comment anonymously

Write a comment

 
Please note: you are not logged in and will be posting anonymously!
= two plus eight

Comments

Rating: 5 of 5

14.Jul.2018 at 10:36 by Mike Keith (2 comments) via Web2 LIVE

Such an interesting way to re-frame how to look at a system. Its inspired me to really take a look at Kafka a little more and explore the ideas presented in this talk.

Rating: 5 of 5

14.Jul.2018 at 11:46 by Philip Sharp (55 comments) via Web2 LIVE

Detailed and engaging talk. Very well delivered.

© Joind.in 2018