Hexagonal Architecture in Practice, Live Coding That Will Make Your Applications More Sustainable by

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

Devoxx

Devoxx

Күн бұрын

Пікірлер: 16
@avwie132
@avwie132 2 ай бұрын
Without a a doubt on of the best talks I’ve seen on architecture. Explaining both the why and how.
@isurucumaranathunga
@isurucumaranathunga 2 ай бұрын
One of the best explanations ever on the Hexagoanl Architecture. Thanks a lot
@TimVanMeerbeeck
@TimVanMeerbeeck 2 ай бұрын
Nice Demo and one of the best Hexagonal implementations in java that I have seen. The domain are plain POJO's! (Well records so not so old :p)
@ZynthCode
@ZynthCode Ай бұрын
Great presentation.
@morkhoudia9
@morkhoudia9 2 ай бұрын
You have explained well the h.architecture
@eugenelukash
@eugenelukash 2 ай бұрын
A word of caution: in microservices, these multilayer approaches are too expensive and brings no return of investments. If the service is reasonably small, it should be able ok to rewrite it or make a significant change to it. And refactoring is necessary to keep maintainable structure of a program in the face of non-trivial changes. Having many layers and conversion between layers with mostly duplicated data models makes it almost impossible to change code in any significant amount and on a limited budget. The performance is a problem too, DB access and other important practices (data oriented design in general) are not taken into account seriously (it's just a persistence layer, right). These patterns easily led engineers to create expensive but not really performant or scalable systems, which are hard to evolve, being brittle and fragile. The whole system then would be a distributed monolith, where each microservice would be a layered micro-lith on its own.
@peterdz9573
@peterdz9573 2 ай бұрын
I do not agree with most of your post, but the point "the db access is just an infrestructure" is very valid. You cannot expect db access to be outside of domain in any data intensive application. Your business logic will be embedded in sql statements as it is most performant way to retrieve/modify big data.
@rohansachdeva627
@rohansachdeva627 2 ай бұрын
Nice clean demo. Stub inside the prod code was something that I still can't get my head around. What would be other place to keep those stubs? In infrastructure?
@julientopcu
@julientopcu 2 ай бұрын
Yes absolutely. As I mentioned in the talk, it was to show that you can provide some kind of intelligent stubbed service for your consumers. If you don't need that kind of "beta test", you can simply keep the stub in the tests. You can also create an Stubbed implementation of the SPI in the infrastructure.
@Curiosidades-ki2oi
@Curiosidades-ki2oi 2 ай бұрын
Great presentation! I had experience working with hexagonal architecture, but the domain used spring annotations to inject the beans, I had never thought of it that way. I was in doubt about the infrastructure, the layer that calls swap api could be a module, no? Just like the controller layer could be another module, what do you think? And I also don't understand the part of the controller where you're returning the same object used in the business layer, you could use mapstruct to do the ApiObjectResponse and BusinessObject conversions, so that when you added the new field, you hadn't broken your customers, because it's just a field that isn't being serialized in your controller.
@sakshamsethi4123
@sakshamsethi4123 2 ай бұрын
What about the cases where you want to let's say cache returns from a service method. Spring Boot offers a @Cached annotation which can cache the return from the method. But since we won't be using spring in domain module no more, we won't have access to this capability and will have to roll our own cache. Do you have a strategy to handle this ?
@christianluzzetti9677
@christianluzzetti9677 Ай бұрын
When it happened to me, i followed various approaches: A. If the cache is not part of the business-logic, I used the cache at repository level (on the SPIs implementation instead that putting it on the service) B. In the domain service, I've put another SPI, so, two interfaces, something like: starshipInventory starshipCachedInventory And wrote something like: result = starshipCachedInventory.find() .or(starshipInventory::find2) .orElseThrow(() -> new ElementNotFoundException()) C. I add a "Service" layer to the architecture. It basically imports the Domain Layer in the dependencies, but it does the CDI plumbing, and there I'm allowed to use Spring Boot annotations. The service class has the @Service annotation (And others, like @Transactional, @Cached, ecc...), it just Autowires the needed repositories, and calls the methods on the Domain Layer (I'm pretty sure "Tom Hombergs" has videos, and wrote a book about it) A is a simpler approach. B lets you implement/swap your cache, starting with a simple HashSet and then upgrading to Redis or something external C If you need a bit more complex hexagonal architecture
@niocode
@niocode Ай бұрын
very nice
@ebuzertahakanat
@ebuzertahakanat 2 ай бұрын
Hİ Julien, great talk it motivated me to do hexagonal architecture with Jakarta EE and there is one thing i can't get my head around it, the trick at 29:00 you talk about. how to do that with JPA and CDI, thank you again for the talk. I mean how to use model classes as @Entity without cluttering the model.
@arvydasguscia9127
@arvydasguscia9127 2 ай бұрын
I think it would be completely different classes with JPA annotations. Same as SwapiResponse is mapped to StarShip in the presentation, some kind of StarShipEntity (sitting in JPA layer) will be mapped to StarShip as well. But I can be wrong.
@ITV-ITV-
@ITV-ITV- 2 ай бұрын
by Julien Topcu
Valhalla - Where Are We? by Brian Goetz
52:07
Devoxx
Рет қаралды 8 М.
Tuna 🍣 ​⁠@patrickzeinali ​⁠@ChefRush
00:48
albert_cancook
Рет қаралды 148 МЛН
Support each other🤝
00:31
ISSEI / いっせい
Рет қаралды 81 МЛН
Microservices are Technical Debt
31:59
NeetCodeIO
Рет қаралды 719 М.
7 Design Patterns EVERY Developer Should Know
23:09
ForrestKnight
Рет қаралды 187 М.
Hexagonal Architecture (Alistair Cockburn)
56:16
Tech Excellence
Рет қаралды 8 М.
Clean Architecture in Next.js: A Complete Implementation Guide
53:07