Building microservices with event sourcing and CQRS

  Рет қаралды 113,046

SpringDeveloper

SpringDeveloper

Күн бұрын

Пікірлер: 52
@ryumak
@ryumak 5 жыл бұрын
One of the better CQRS design pattern explanations, describing the concept, pros and cons in the context of DDD and distributed systems.
@vectorhacker-r2
@vectorhacker-r2 7 жыл бұрын
This is an amazing talk. I always go back to it when I have doubts, by far the best explanation of CQRS.
@pumbo_nv
@pumbo_nv 7 жыл бұрын
Great video. I'm just starting to learn how distributed systems work. After having worked many years with traditional systems (monolithic/ rdbms) it's fascinating to learn these new concepts.
@denniszhang2147
@denniszhang2147 7 жыл бұрын
Love it and watched by 1.5 speed. Thanks for uploading!
@dnvriend
@dnvriend 8 жыл бұрын
Absolutely great talk I would like to add that Akka is a great way to implement a DDD model. Event sourcing comes out of the box when used with Akka persistence (which is just an addition to the actor model). I've tried using plain old Java with Spring, but the Scala/Akka combo is just great, because most things are available in the Actor library.
@avneet12284
@avneet12284 7 жыл бұрын
dnvriend does it make sense to learn scala? I've heard great things. I am a Java dev
@dnvriend
@dnvriend 7 жыл бұрын
It is my opinion that it is always good to learn new things but in the case of creating applications that are modeled using DDD, Scala in combination with Akka makes it very easy to create highly scalable applications for the JVM. The concise syntax of Scala makes it very easy to implement applications that are modeled leveraging DDD and the Scala bias to immutability makes the application cloud scale ready, even if you don't need that at first.
@stephaneislistening6103
@stephaneislistening6103 6 жыл бұрын
You can use Akka in Java as well.
@Oswee
@Oswee 6 жыл бұрын
Go, gRPC and Kafka suits so perfectly for this architecture. Playing with it and trully love it.
@waqasrana7891
@waqasrana7891 4 жыл бұрын
can you please share link of guide/tutorial/content related to this stuff ,specially kafka in micro services etc
@wangmurphy3179
@wangmurphy3179 7 жыл бұрын
Much appreciate if anyone know, where is the sample Scala code from Martin Fowler mentioned in this video at time point 1:20:10 ?
@marcjost5859
@marcjost5859 5 жыл бұрын
@Michael Plöd Fantastic Talk, thank you so much. Just a quick question regarding "Never change events". How do you handle compatibility with future versions? Let's say you are developing an application and you get it running, publishing events in version 1. Some time later you have further developed your application and you had to change those events. In order to be processed correctly in case of a "replay", the old events would have to adhere to the new event version. Any recommendations on this?
5 жыл бұрын
I think there's many ways to do that, but you could add a "version" attribute to your events. The aggregates will need to be able to deserialise correctly all versions of an event, though.
@muatik
@muatik 5 жыл бұрын
by the way, on one of the slides, CQRS was shown as CQR separation, but it is segregation, not separation. there is yet another abbreviation CQS that stands for Command query separation. en.wikipedia.org/wiki/Command%E2%80%93query_separation#Command_query_responsibility_segregation
@ravikumar-kh9gi
@ravikumar-kh9gi 4 жыл бұрын
Best explanation I have ever seen.
@grayfox8905
@grayfox8905 7 жыл бұрын
Are there any code samples to go along with this talk?
@xprt642
@xprt642 8 жыл бұрын
Where is the "microservices" part? Nowhere to be found.
@michaeldeng1981
@michaeldeng1981 3 жыл бұрын
2021, CQRS, Event Sourcing becomes the mainstream for microservice architecture.
@lmb_codes
@lmb_codes 8 жыл бұрын
1/3 of the video and i think this is VERY VERY INTERESTING!!!
@SanjayRoy-gm8ej
@SanjayRoy-gm8ej 8 жыл бұрын
Fantastic explanation of CQRS/Event Sourcing Micheal!! A quick question though, isn't "S" of CQRS is "segregation" instead of "Separation" , though it might just be trivial.
@therealxtagon
@therealxtagon 7 жыл бұрын
Greg Young's CQRS documents use the word "segregation" but it also mentions that it "originated with Bertrand Meyer’s Command and Query *Separation* Principle" - neither of you are wrong of course :-)
@mcqueenalexander8322
@mcqueenalexander8322 2 жыл бұрын
How can I get a sync response from CQRS?
@SanjeevKulkarniWorld
@SanjeevKulkarniWorld 5 жыл бұрын
Great explanation, nice presentation and simple and clear understandings...
@USONOFAV
@USONOFAV 6 жыл бұрын
redux + microservice = event sourcing architecture?
@kirens8897
@kirens8897 7 жыл бұрын
In the case of validation mentioned in 54:20, how the 2 users with same email address get entered in the system? Are you not validating? I didn't get that point, can any one help me
@stas546
@stas546 6 жыл бұрын
He explained it pretty straight and answer is you validate against read model which might not be up to date and you have inconsistent event store state now... and author says that it is not a big deal... it is a huge deal, I understand cool aspects of event sourcing but this fundamental eventual consistency is just a huge inconvenience. It is not only user registration there might be tens of examples where I want to validate current state of the system before commit next event and every time I should email a manager or make a discarding event?
@visitforthemusic
@visitforthemusic 6 жыл бұрын
@Stan Agreed and for the duplicate email address example used it would be very hard to explain to someone non-technical how it had occurred whilst maintaining a serious face. It also opens opportunities for malicious exploitation of inconsistent state. It does feel like going back to go forward.
@arithmeticerror
@arithmeticerror 6 жыл бұрын
CQRS as it stands today has very little value unless the business can live with its fundamental limitation of eventual consistency. Instead of accepting this limitation, proponents of CQRS turn the tables and say Strong consistency is bad. There is no sane way to get around eventual aspect. Commands are forced to go to event handler to get processed as and there is no sane way to achieve consistency without compromising latency How many businesses want their customer to signup again later because the event handler was busy handling other events. Sure, we can throw a lot of resources to achieve consistency, but is it really worth it? Sharding is a reasonable alternative if load on single strong consistent store does not scale well. May be distributed SQL stores like cockroach db might help if used smartly The only value you have is event sourcing which allows us to have business events & the ability to replay
@mguven
@mguven 5 жыл бұрын
Author's statement on this issue made me also uncomfortable because it is not such a process as simple as he defined when you look from the view of user perspective. I think (at least this is what I understood) what he wanted to mention was focus on your domain subject and if what you interested in that manner is out of the main domain then don't give too much care on it. In this particular case, if your main objective is not registering user (along the whole application) then skip this parts with simple actions???
@bluejanis5317
@bluejanis5317 7 жыл бұрын
How do you save different states of the read-model if you have it (only) in memory? I am wondering how you would save old events combined, so you could start with that and only apply new events.
@devrexable
@devrexable 7 жыл бұрын
This is called snapshots. You would typically write code that dumps the in-memory model to persistent storage and read it back again when the system starts up. This is not necessarily faster than just replaying all the events, depending on the size and complexity of the projection and th number of events.
@MickeyMouseLoveSong
@MickeyMouseLoveSong 6 жыл бұрын
At 12:12 how can user click if his mouse is broken? :)
@ajaykotnala4129
@ajaykotnala4129 6 жыл бұрын
can we get the code sample or step by step code guide where new babies like me can understand more about this? this is one of the best video i have seen of this topic. i am still sightly confuse about CQRS that how read and write will happen. but i guess if i can get sample code it will be more helpful.
@ajaykotnala4129
@ajaykotnala4129 6 жыл бұрын
for eventsourcing nice and sort example you can find github.com/RisingStack/event-sourcing-example it is in nodejs but the concept is really sort and simple
@anug14
@anug14 7 жыл бұрын
ok... lets say we are using in memory data base for data store ... when ever the application is down ...we need to rebuild everything using event source from the beginning ... what if it happens after 2 years ?
@devrexable
@devrexable 7 жыл бұрын
Loading millions or billions of events can take from a few minutes up to a couple of hours. If you have multiple replicas of each in-memory readmodel you can perform a rolling upgrade without downtime.
@anug14
@anug14 7 жыл бұрын
i think every domain is unique and one should choose architecture based on one's own analysis.However just as an opinion poll - do you guys think this approach is good for Supply Chain Systems.
@erickkoskey7410
@erickkoskey7410 2 жыл бұрын
Hello Anug14, yes its good since we have several actors within the supply chain and the events happens in a sequential manner. You can think of reversals which entails transactions compensation
@trieder
@trieder 8 жыл бұрын
clear and easy exlanation. Great!
@sahilgupta3468
@sahilgupta3468 7 жыл бұрын
Loved it !
@guillermozanoletti3470
@guillermozanoletti3470 6 жыл бұрын
A very good talk!
@tkousek1
@tkousek1 6 жыл бұрын
Great job!!
@jaiverma3090
@jaiverma3090 Жыл бұрын
thought provoking talk
@PatrickCornelien
@PatrickCornelien 6 жыл бұрын
"Never delete/modify events" is basically not possible due to GDPR. You are legally forced to remove or anonymize user data if the user requests it or cancels your service
@michaelploed
@michaelploed 6 жыл бұрын
Please mind that this talk has been given before GDPR ;-) I usually mention in my talks that data protection rules may force you to break that rule
@t.peterson4942
@t.peterson4942 6 жыл бұрын
One thing that was pointed out in another talk about CQRS and GDPR. When creating a new object have an event that generates an encryption key and add to the event queue. All user data can be encrypted using the encryption key and events are saved that way. The only thing that has to be modified if the user asks to be removed is to remove the save of the encryption key event. Now the data is encrypted and cannot be recovered but the events are not changed. This adds some overhead but if you are judicious with using data objects to save the personal data so encryption can happen on a block of data instead of fields at a time.
@barkhagupta
@barkhagupta 8 жыл бұрын
don't you think "CustomerVerifiedEvent" should be named as "CustomerVerificationEvent" because you don't know the outcome of the event, the customer passed verification or failed verification??? But "CustomerVerifiedEvent" always indicates passed logically...what about if verification failed?
@borelatech
@borelatech 8 жыл бұрын
If you need a special logic for when the customer failed the verification, you would have to create an event "CustomerFailedVerificationEvent", basically you create the events you need for the business logic but the events must always indicate what happened.
@devrexable
@devrexable 7 жыл бұрын
plaintext passwords in the examples? Ouch!
@genericperson8238
@genericperson8238 3 жыл бұрын
Please learn the difference between “parallel” and “concurrent” its highly irritating. And no, that isn’t some nitpicking detail because those terms are different things which can and often do pop up in the same context
Developing microservices with aggregates - Chris Richardson
1:09:50
SpringDeveloper
Рет қаралды 277 М.
Webinar: Bootiful CQRS with Axon
1:25:25
SpringDeveloper
Рет қаралды 28 М.
小丑女COCO的审判。#天使 #小丑 #超人不会飞
00:53
超人不会飞
Рет қаралды 16 МЛН
Сестра обхитрила!
00:17
Victoria Portfolio
Рет қаралды 958 М.
Webinar: Introducing Spring Cloud Task
48:50
SpringDeveloper
Рет қаралды 9 М.
Reactive DDD: Modeling Uncertainty - Vaughn Vernon
1:15:16
SpringDeveloper
Рет қаралды 22 М.
Securing Microservices with Spring Cloud Security
1:29:52
SpringDeveloper
Рет қаралды 100 М.
DDD & REST - Domain Driven APIs for the web - Oliver Gierke
1:15:16
SpringDeveloper
Рет қаралды 168 М.
Event-Driven Architectures for Spring Developers
1:09:44
SpringDeveloper
Рет қаралды 38 М.
I can't believe it's not a queue: Using Kafka with Spring
27:49
SpringDeveloper
Рет қаралды 43 М.
Developing Real-Time Data Pipelines with Apache Kafka
1:30:40
SpringDeveloper
Рет қаралды 157 М.
Spring Office Hours: S3E41 - Spring's Hidden Powers with Greg Turnquist
1:05:28
Frustration-Free K8S for Spring Developers (SpringOne 2024)
37:51
SpringDeveloper
Рет қаралды 7 М.
Scaling APIs With Spring Cloud
41:41
SpringDeveloper
Рет қаралды 3,8 М.