Video: Event-Driven Microservices, the Sense, t…
Event-Driven Microservices, the Sense, the Non-sense and a Way Forward - Allard Buijze
(https://www.youtube.com/watch?v=jrbWIS7BH70)
Why microservices
data:image/s3,"s3://crabby-images/fe19d/fe19d924849d7c9849eaba2a9a0e3db798f7d473" alt=""
monolith that is well-structured, can scale as well
data:image/s3,"s3://crabby-images/6e02b/6e02b1a5a81b855e912429bdead0560283615385" alt=""
What goes in one service?
What goes in another?
data:image/s3,"s3://crabby-images/5dcb7/5dcb7c781291453575851e374f7c344ef4476e6b" alt=""
order
customer
product
inventory
data:image/s3,"s3://crabby-images/58e00/58e00b748a1d71b64e377005235c57df3493210b" alt=""
Are you micro-pile-of-shit?
- redeploy multiple services at one
- strong dependencies on other service before you can do something
data:image/s3,"s3://crabby-images/8e9c5/8e9c5ef95b09c3d9d4296ee23f742c48cfd408bf" alt=""
"just go up, and then go right"
anti-modularity forces
data:image/s3,"s3://crabby-images/14226/14226259aa2244bc3386cf1cd7cb1bca74b91937" alt=""
suit & tie telling you "the deadline shifted"
technical debt
data:image/s3,"s3://crabby-images/39517/395177aa8221273de41b4458fde138c2f8ee8b63" alt=""
"""
it's all about discipline
if you can't wax a car, forget about karate
If you can't build a monolith, forget about microservices
"""
there is a journey towards microservices
1) build monolith
2) compnents
3) split off services => non-functional requirements
data:image/s3,"s3://crabby-images/8f2ad/8f2adc26828821eb2227a4071784ce4c3fc97e7c" alt=""
assume components are not on the same deployment
data:image/s3,"s3://crabby-images/3c296/3c296480b3a6119dfed33b525ba4400306ea586c" alt=""
inverted
data:image/s3,"s3://crabby-images/2feed/2feedc69efae7fdbb7a9990414fd7e8fbe449b5f" alt=""
data:image/s3,"s3://crabby-images/aa055/aa055154f84c8ac8632827cfe4672ac1d3e9ff00" alt=""
"if all you have is a hammer, everything looks like a nail"
event patterns
data:image/s3,"s3://crabby-images/2bbc2/2bbc285c2a528cc218f1f5f1f161d0dd677637da" alt=""
event notification: "something changed"
event-carried state transfer: "this changed"
event sourcing: everything becomes an event
data:image/s3,"s3://crabby-images/7fa83/7fa833694d3a169c59bf7a87f1bec1a3892b8b13" alt=""
duplicate logic
item is ordered if added, not removed, then ordered
data:image/s3,"s3://crabby-images/92d7e/92d7eb94b328dd07b8a81956e20cabd299e409d6" alt=""
data:image/s3,"s3://crabby-images/4b83f/4b83f2ab47fc87efc9b5d3e6096826d7cd13700f" alt=""
event: explain something happened
command: intent to change something
queries: need for information
data:image/s3,"s3://crabby-images/b45c8/b45c84b7edd59f9a638e749d9c4d78f54cb259af" alt=""
=> event notification
data:image/s3,"s3://crabby-images/1cbd9/1cbd90ac10fd95e406ee932b1399cf75b949232c" alt=""
!= just save all the events
data:image/s3,"s3://crabby-images/7d66a/7d66a29d24998918fd89ae872cd81d2764898646" alt=""
data:image/s3,"s3://crabby-images/e4bd4/e4bd4423bcd9d596e3ec53aa06a95d4f97ec7029" alt=""
event handling
Event sourcing check:
throw away everything, except your eventstore
data:image/s3,"s3://crabby-images/3de77/3de77feed305c3d28696c517611171226d7cbae2" alt=""
data:image/s3,"s3://crabby-images/9e02b/9e02b816be49cb60ef2d70a2323a74f57f3a3419" alt=""
storage is cheap
everything is complex at first
forget about state, think about behavior
data:image/s3,"s3://crabby-images/9a912/9a912b78e22bc0e7c2240a4c54c6e53b59c68202" alt=""
"if all you have is a hammer, everything looks like a nail"
data:image/s3,"s3://crabby-images/bcf62/bcf62a846d7fe1f91b8833eea9d34940c81d7a62" alt=""
:) can I do this one change?
:( "give me all orders above 100$"
data:image/s3,"s3://crabby-images/252ef/252eff84f424ed441cd4f339898522382125e652" alt=""
:) can I do this one change?
:) "give me all orders above 100$"
data:image/s3,"s3://crabby-images/2cf0c/2cf0ccebea28a087e2def948309e5f5819fcf21e" alt=""
events -> contracts with unknown services
consumer driven contracts
data:image/s3,"s3://crabby-images/49e92/49e9243fe0d9b6ee0c3a07031182bd3eacc7f21e" alt=""
within context, want details
across borders, high level
assign services to bounded context
data:image/s3,"s3://crabby-images/62743/62743aac6b8b7158a9067ac712fd6527530fa391" alt=""
anti corruption layer
data:image/s3,"s3://crabby-images/c8f7f/c8f7f5ccaa2779a45a42fb38d20c85646581eadb" alt=""
data:image/s3,"s3://crabby-images/dfb86/dfb86c4e547023f5f4539d4692e86c2b09700c19" alt=""
data:image/s3,"s3://crabby-images/b2790/b2790ec5fdad344ea5788934a515b7b11a03e93c" alt=""
use them as explicitly as events
data:image/s3,"s3://crabby-images/39717/39717d26c701f471587fcfb17ff21a0784269b70" alt=""
data:image/s3,"s3://crabby-images/4335f/4335f89b387140f1d3aa064cf869583dd0619679" alt=""
monolith first
disciplined modules
split off services