Change Data Capture + Event Driven Architecture

  Рет қаралды 13,927

CodeOpinion

CodeOpinion

Күн бұрын

Пікірлер: 32
@CodeOpinion
@CodeOpinion Жыл бұрын
Are you using CDC? What's the use-case?
@LilPozzer
@LilPozzer Жыл бұрын
j
@viktorshinkevich3169
@viktorshinkevich3169 Жыл бұрын
4:19 and CDC itself can also capture specific views instead of tables directly so it would be another layer of separation. As a service B owner I can change internal of schema whatever I like as long as I comply with my contract so having CBC targeted to db view could ease that process
@bayonnesensei8281
@bayonnesensei8281 Жыл бұрын
I agreed with you, I am using the same approach in production which I've do CDC at View Level instead of making CDC in a database table.
@rz5541
@rz5541 Жыл бұрын
Always a pleasure watching your videos - many thanks for sharing all this good knowledge
@CodeOpinion
@CodeOpinion Жыл бұрын
Thanks. Appreciate you watching.
@evanhobbs
@evanhobbs 8 ай бұрын
This was an excellent explanation and very timely. Thanks!
@Vale-ck9rz
@Vale-ck9rz Жыл бұрын
Perfect timing 😂. This Saturday I will present my thesis that shows IDM solutions that use event-driven architecture and Derbezium software.
@pieter5466
@pieter5466 11 ай бұрын
"Data on the inside is different than data on the outside." Under-appreciated point, had not yet heard it articulated thus.
@CodeOpinion
@CodeOpinion 11 ай бұрын
I also often say Private vs Public to get across the same gist.
@thomas-sinkala
@thomas-sinkala Жыл бұрын
Thank you for making this.
@CodeOpinion
@CodeOpinion Жыл бұрын
My pleasure!
@coolcoolj0102
@coolcoolj0102 Жыл бұрын
Can you share some available open-source CDC tool/library?
@dbpieter
@dbpieter Жыл бұрын
Debezium, mentioned in video
@ArtemKhodos
@ArtemKhodos Жыл бұрын
Thank you Dereck, awesome explained as always! Right now I am working on decoupling my own domains from monolithic application to own service. Some tables can be just moved, but looks like a have to copy a few tables as they are used in infra layer in "my" domains. I think CDC might be a good option to keep the data consistent.
@CodeOpinion
@CodeOpinion Жыл бұрын
Depending on the usage, another option is providing a API that exposes that underlying data so you aren't accessing it from a replicated table (assuming that's what you mean).
@shahrazkl
@shahrazkl Жыл бұрын
Amazing video
@pradeepsahoo7243
@pradeepsahoo7243 Жыл бұрын
I get the usecase of CDC that should have different structure which describes a business event instead of a CRUD event, but that translation from database logs seems challenging, however, what could be easier to do is if a transaction happens at Application A, we don't care what it persists to its own state ful data source and it can very well publish the transaction to an event streaming platform and the whole usecase for CDC can go away.
@neal321
@neal321 Жыл бұрын
I understood CDC to be more for integration at the data layer, for replication, data warehousing, ETL etc. In the example of Service B using CDC to go though a translation layer to write a message to the message broker, would it not be simpler for the service layer to publish a message to the broker itself, since it would have the business context at this stage and not introduce CDC and a translation for event driven architecture? It seems like a complication to me since all database updates should be going through the service anyway as you point out? Great channel by the way!
@CodeOpinion
@CodeOpinion Жыл бұрын
Yes, while that would be ideal, if it's a legacy system, most start using CDC as away to derive events because there may not be a single point of truth for making state changes. Meaning you have multiple applications or processes that might be changing data without having any control over if they are publishing the required event.
@neal321
@neal321 Жыл бұрын
@@CodeOpinion Ok yes, that makes sense for a legacy application or proprietary system where you don't have access to change the code, now that I think of it I have used this strategy in the past for an old school POS systems on their MSSQL database, thanks for the reply
@MrSpyTubes
@MrSpyTubes Жыл бұрын
@@CodeOpinion But is this translation layer a Service's B responsibility ? Because it might be difficult for a legacy system to do it, and cdc is seen as a way to gather data from that system without making changes to it.
@pradeepsahoo7243
@pradeepsahoo7243 Жыл бұрын
​@@MrSpyTubes In this particular usecase, Service A is legacy, so, no control over which process is writing to DB and how, Service B is a newer more flexible service and needs real-time events to update DWs, Caches, etc. The CDC process needs to have some of the business logic to not only read the CRUD events from DB logs, but transform it into a business event. Now, that's only possible to do if the underlying data structure is understood and some business logic from the Service A application is applied to transform the CDC event before publishing to the event streaming broker.
@ilijanl
@ilijanl Жыл бұрын
Great video, like neal already mentioned, CDC probably shouldn't be used for integration events. I wonder how you would integrate a warehouse inside a business, especially having multiple (external) services. Would you use CDC, ETL or ELT or some other methods?
@CodeOpinion
@CodeOpinion Жыл бұрын
Not mutually exclusive, could be a combination.
@NervousNab
@NervousNab Жыл бұрын
is outbox pattern a specific implementation of cdc?
@CodeOpinion
@CodeOpinion Жыл бұрын
You could use CDC in that way to publish events. I would persist the actual events in the db and have cdc process publish those rather than trying to infer and transform a data change to an event.
@shahrazkl
@shahrazkl Жыл бұрын
We have high number of tnx on sql server, Could enabling CDC affect overall SQL performance?
@Variant55
@Variant55 Жыл бұрын
Late reply, but yes. CDC adds overhead and this could negatively impact the server.
@haraheiquedossantos4283
@haraheiquedossantos4283 Жыл бұрын
It seems like CDC is a great choice in scenarios that we are using event in data centric way to do some data distribution/propagation or something like that, so I mean, in event carried state transfer. Do you agree?
@CodeOpinion
@CodeOpinion Жыл бұрын
Yes, I'd say CDC is closer to event-carried state transfer than anything. I'm always very cautious with it because sharing data between services is not something I advocate. It depends on what the data is for and how it's being used.
@pradeepsahoo7243
@pradeepsahoo7243 Жыл бұрын
​@@CodeOpinion So, I understand not sharing data between services means not sharing the underlying data structure or data storage system between services which couples different services together and creates complexity which can't be easily managed or broken down. So, sharing the business events as CDC is more desirable approach.
Building a system that Junior Developers can be productive in
8:05
Don’t Choose The Wrong Box 😱
00:41
Topper Guild
Рет қаралды 62 МЛН
Гениальное изобретение из обычного стаканчика!
00:31
Лютая физика | Олимпиадная физика
Рет қаралды 4,8 МЛН
Сестра обхитрила!
00:17
Victoria Portfolio
Рет қаралды 958 М.
Debezium - Capturing Data the Instant it Happens (with Gunnar Morling)
1:02:47
Why is Clean Architecture so Popular?
11:52
CodeOpinion
Рет қаралды 50 М.
DTOs & Mapping : The Good, The Bad, And The Excessive
11:03
CodeOpinion
Рет қаралды 19 М.
Movie Recommendations - ML System Design Interview
9:05
TRYEXCEPT
Рет қаралды 1,4 М.
You want to use Kafka? Or do you really need a Queue?
11:43
CodeOpinion
Рет қаралды 24 М.
The pendulum swings! Microservices to Monoliths
10:29
CodeOpinion
Рет қаралды 25 М.