Avoiding a Big Ball of Mud! Coupling in a Monolith

  Рет қаралды 6,606

CodeOpinion

CodeOpinion

Күн бұрын

Пікірлер: 35
@OllyWood688
@OllyWood688 4 жыл бұрын
_"I think delegates are way underused in this context, and they're exactly that same thing; They're a contract."_ ...man. That was inspiring.
@CodeOpinion
@CodeOpinion 4 жыл бұрын
Not sure if you're serious or being sarcastic? I know sometimes I can get a bit monotone.
@OllyWood688
@OllyWood688 4 жыл бұрын
That was genuine admiration :) ^and this is not sarcastic either, please believe me aaaaah Sometimes I catch myself looking for elegant solutions in the most complex of approaches, but overlook that many things already are functional in a simple, elegant, and obvious way. That's what I meant with inspiring. No need to piggyback a huge ass nuget if what you want to accomplish can be done with just some minding the tools you HAVE. Thanks for the reminder to stop and breathe a little :)
@CodeOpinion
@CodeOpinion 4 жыл бұрын
Thanks 👍. I really do appreciate the comment.
@AntonioCastroJunior
@AntonioCastroJunior 4 жыл бұрын
Hi Derek, How would you organize the solution to have separated modules but just one database with schemas for each module? Is it ok to have a separated project in the solution with, for instante, an EF context referencing the entities directly like: public Dbset Orders{get;set;}
@CodeOpinion
@CodeOpinion 4 жыл бұрын
Each module/project having it's own DbContext. They shouldn't share or have any of the same DbSet however.
@AntonioCastroJunior
@AntonioCastroJunior 4 жыл бұрын
@@CodeOpinion Is it possible to have multiple DbContexts pointig to the same database with different schemas? How migrations would work?
@CodeOpinion
@CodeOpinion 3 жыл бұрын
@@AntonioCastroJunior Yup. Each dbContext will have it's own connection, just pointing to the same DB instance.
@adamali89
@adamali89 3 жыл бұрын
I really appreciate your efforts!. I wish if you would create series on identity server with monolith and boundaries that how one should implement authentication and authorization with all these concepts.
@CodeOpinion
@CodeOpinion 3 жыл бұрын
I'll add it to the list of topics. Thanks 👍
@yevheniikurtov5990
@yevheniikurtov5990 3 жыл бұрын
Derek, there is a very dangerous slip of the tongue at 1:29 - boundaries are defined in collaboration with domain experts. This problem can't be solved exclusively within the engineering room.
@CodeOpinion
@CodeOpinion 3 жыл бұрын
Of course.
@argentum_serebro
@argentum_serebro 3 жыл бұрын
Hi Derek! Thanks for the inspiring ideas you're presenting in your videos! If you would get a tasks to decouple a so cold "ball of mud" monolith how would you approach the analysis for future refactoring ?
@CodeOpinion
@CodeOpinion 3 жыл бұрын
Find the boundaries. Leverage events to start decoupling. I should create a video on this topic!
@argentum_serebro
@argentum_serebro 3 жыл бұрын
@@CodeOpinion that would be awesome! Looking forward to it!
@romanlunin386
@romanlunin386 2 жыл бұрын
Hi Derek, according to the Clean Architecture you could create an even looser coupling by defining contracts inside the same boundary, e.g. define IWarehouseInventory under Sales boundary, this way Sales has no foreing dependencies at all, do you think it worth it?
@CodeOpinion
@CodeOpinion 2 жыл бұрын
Yup, you could if you would get benefit from having that interface. By all means, if not, don't bother creating an abstraction with a single implementation.
@thilehoffer
@thilehoffer 3 жыл бұрын
How do you inject an implementation without a project reference to the implementation project?
@CodeOpinion
@CodeOpinion 3 жыл бұрын
Ultimately the executing project (aspnetcore) is doing the injection and has all the references. So you only need a reference to the interface/delegate.
@thilehoffer
@thilehoffer 3 жыл бұрын
@@CodeOpinion Thanks for the response. So the asp.net core project can reference all the implementations but the other project only reference the contracts. Also, I love the idea of using delegates instead of always using interfaces. Good stuff.
@antoniocastrojunior684
@antoniocastrojunior684 4 жыл бұрын
Hi Derek, in my experience, systems always start small like a baby, but babies grow. Implementations calling contracts outside their own boundaries seems like syncronous api calls. What do you think of using messages just from the beggining in order to minimize the impact of changes when you need to separate a module (boundary) as a microservice? Thanks for the great series.
@CodeOpinion
@CodeOpinion 4 жыл бұрын
Ya I've been advocating messaging within a monolith. However I wanted to create a video that if you're not going to go the messaging route, or already have a large project that makes synchronous API calls between boundaries, to do so via interfaces and delegates(functions) that are defined in a separate contracts project.
@janhendrikschreier
@janhendrikschreier 4 жыл бұрын
I am just reading Enrico Buonanno's book Functional Programming in C# where he also suggests more delegate-usage. Thus your video on using delegates arrived just in time for me:) I liked the demo-part with the registration of the delegate and and how you make it part of the contract with an extension method. thanks for the video!
@CodeOpinion
@CodeOpinion 4 жыл бұрын
Shhhh... don't tell anyone I'm trying to slip in some functional ideas into these videos!
@janhendrikschreier
@janhendrikschreier 4 жыл бұрын
@@CodeOpinion I continued reading the book and now I know where this will all end: "In the last chapter, you saw that in FP we avoid mutating state, especially global state. Did I mention that the database is also state, so it too should be immutable? What? Yes, didn’t you see this one coming? A database is, conceptually, just a data structure." aaaaaahhh! If someone had told me before! This whole FP stuff is like watching a KZbin video on how to boil an egg and five hours later you're convinced that Lizard's rule the world ;)
@andrewthompson9714
@andrewthompson9714 2 жыл бұрын
@@janhendrikschreier this book changed my career. I recommend it to every c# developer and it's required reading on my team
@janhendrikschreier
@janhendrikschreier 2 жыл бұрын
@@andrewthompson9714 If you liked that book, Grokking Simplicity is even better. It uses Javascript in its exampled but as a c# dev it is easy to read
@stuartbradley5761
@stuartbradley5761 3 жыл бұрын
Hey great video and great series. I've been spending some time looking at modular monoliths and loosely coupled monoliths as I've had bad experiences with big balls of mud. However I'm stuck on one area which is querying. I follow CQRS and use entity for my commands and dapper for my reads. Should I query across boundaries? The UI might require information from two different schemas. Any advice?
@CodeOpinion
@CodeOpinion 3 жыл бұрын
You will need to do composition somewhere. That can be in the UI by making multiple queries. If that's not ideal in your situation, you can have the server do the composition so you only have one call to the server from the client. You can also develop UI components that are owned by a specific context and use those to build a composite UI. Is a big topic :)
@richardbrown1300
@richardbrown1300 3 жыл бұрын
@@CodeOpinion I'd love to see you do a video on implementing UI in a loosely coupled monolith. This is a great series
@Cypressious
@Cypressious 4 жыл бұрын
In response to delegates, couldn't you just split the interface into multiple interfaces and let the class implement all of them?
@CodeOpinion
@CodeOpinion 4 жыл бұрын
Yup. However, if you have an interface with one method... you just want a function. But yes, maybe split them into more specific interfaces.
@Cypressious
@Cypressious 4 жыл бұрын
@@CodeOpinion you're right, but interfaces need a LOC less to register with the DI 😃
@matthewbrookson
@matthewbrookson 4 жыл бұрын
Libraries like Moq also solve this testing problem that was mentioned by only requiring you to implement the "fake" or mock methods on the interface that are actually required for a given test. I like the delegate idea but can see class constructors becoming very bloated as you require more delegates to be injected.
SOLID Principles? Nope, just Coupling and Cohesion
13:56
CodeOpinion
Рет қаралды 34 М.
Непосредственно Каха: сумка
0:53
К-Media
Рет қаралды 12 МЛН
«Жат бауыр» телехикаясы І 30 - бөлім | Соңғы бөлім
52:59
Qazaqstan TV / Қазақстан Ұлттық Арнасы
Рет қаралды 340 М.
Почему Катар богатый? #shorts
0:45
Послезавтра
Рет қаралды 2 МЛН
Asynchronous Messaging in a Loosely Coupled Monolith
11:20
CodeOpinion
Рет қаралды 12 М.
How Well Designed Are Your Microservices?
19:44
Continuous Delivery
Рет қаралды 32 М.
Defining Service Boundaries by Splitting Entities
10:43
CodeOpinion
Рет қаралды 9 М.
10 Years of Software Architecture: Best And Worst Decisions
15:09
REST APIs for Microservices? Beware!
11:49
CodeOpinion
Рет қаралды 49 М.
Dependency Injection, The Best Pattern
13:16
CodeAesthetic
Рет қаралды 912 М.
Shared Database between Services? Maybe!
13:51
CodeOpinion
Рет қаралды 25 М.
All Rust string types explained
22:13
Let's Get Rusty
Рет қаралды 197 М.
Writing Code That Runs FAST on a GPU
15:32
Low Level
Рет қаралды 577 М.
Непосредственно Каха: сумка
0:53
К-Media
Рет қаралды 12 МЛН