Dennis van der Stelt
Distributed Systems addict
Rotterdam, The Netherlands
Actions
Dennis is a Software Architect who loves building distributed systems and the challenges they bring. To always be better than the day before, he continuously searches for new ways to improve his knowledge on architecture and software development. He shares what he learns in numerous articles, presentations, and blog posts.
If you want to chat, feel free to ping Dennis on Twitter at @dvdstelt
Area of Expertise
Topics
Implementing the planet's largest e-commerce site in vertical slices
How often did you see a session about any kind of services and heard about how important it was to find the right boundaries, but until now you wondered how to find those boundaries. Or what vertical slices look like once implemented, how they behave and what data they own. And how on earth business data cannot cross its boundaries, but invoices need access to product, customer, and pricing details.
In this session, we'll see an example of how the planet's largest electronic retailer would find the service boundaries for its checkout process. Then we'll look at how each service is part of choreographing this complex business process in an actual implementation. You'll finally understand the full flow from finding service boundaries to implementation and be able to break down a big ball of mud into a maintainable and decoupled system.
Message Queues Demystified: Preventing the Invisible Losses
Message queues are the backbone of modern distributed systems, enabling seamless communication between services. But what happens when messages vanish into the ether, like socks in a dryer? Silent message loss can strike when you least expect it. Obviously, this never occurs during development; it only happens in production. Many systems lose more messages than their developers realize, jeopardizing reliability and consistency.
This session explores how message loss can occur, from race conditions to non-transactional message publishing. We’ll explore mitigating message loss using patterns and techniques like the outbox, transactional session, and idempotency strategies. We’ll also discuss how developers can use RabbitMQ and Azure Service Bus to apply these patterns and ensure reliable message delivery. Join me and gain practical insights into designing resilient systems that safeguard your messages from producer to consumer. Whether building new applications or retrofitting existing systems, this session will equip you with the knowledge to eliminate hidden pitfalls and achieve bulletproof message delivery.
Autonomous services don't share data. Period.
Are you building a monolith using microservices? If a small change in business logic or in data requires you to modify code in more than one service, you probably are. Isn't it unbelievable that even using the latest technologies like .NET Core, containers, serverless and more doesn't help? In this session we'll discuss why technology doesn't change coupling. We'll have a different look at microservices. One where they'll truly be autonomous and not share data at all.
Unique session of 350 slides that I go through in 40 minutes and then possibly present demos. It was build using the Lessig Method Presentation Style. It teaches a different style of modeling your architecture.
Dealing with eventual consistency
As software architects we want to make our systems more performant, maintainable, understandable, or any other thing-able. We use infrastructure like Azure Service Bus or Service Fabric. Maybe we’ll introduce patterns like CQRS and Event Sourcing. Many of these choices introduce eventual consistency, but users expect immediate consistency. They don’t want to wait for eventually. They expect feedback now. There are, however, ways to work around this.
So what exactly is eventual consistency and how can we make it work? In this session, we’ll have a look at different patterns, both in the user interface and the back end, that give our users immediate feedback even though the back-end system is not. We’ll discuss how to solve the complexity of dealing with eventual consistency, without sacrificing decomposability or performance.
Change your architecture during deployment
Many systems start with diagrams of boxes and arrows and the promise of high consistency and low coupling. The boxes are supposed to be loosely coupled components, but each arrow often results in a highly coupled dependency at runtime. What if we can do something about it… during deployment?
In this session, we’ll identify design decisions that influence your system’s behavior both at design-time and run-time. We’ll observe how changing your design during deployment gives you many opportunities for making trade-offs to improve function and performance and gives you the information you need to shape your system architecture.
Workshop: Event Driven microservices in vertical slices
Did you build your system using microservices but ended up with a distributed monolith?
In this workshop, we'll go beyond the hype and build a solid foundation of theory and practice on architectural styles like:
- Vertical Slices Architecture
- Event Driven Architecture
- Microservices Architecture
- Service Oriented Architecture
Without making your system even more complex and unmaintainable, actually look at how we can solve those problems, covering topics like:
- Data ownership across the enterprise
- Fault tolerance of our processes, transactions, and data
- Scalable event-processing endpoints
- Long-running multi-stage business processes and policies
You’ll better understand architectural concepts and DDD concepts such as bounded contexts and data ownership.
We’ll apply those concepts to build a simple, yet fully functional, order management system sample with a microservices architecture, using patterns such as command processing, pub/sub, and long-running sagas.
Some reviews when I gave this workshop before:
- A dedicated trainer, able to explain architecture topics at the level of the listeners. Each time he explained it from a development perspective with code and correlating it with diragrams for the architectural perspective.
- Amazing job, thanks for taking the time to explain these topics to us. Can't wait to apply this knowledge.
- Fun trainer, has a lot of knowledge and lots of experience. It shows.
- Information was interesting and presented clearly. Trainer's enthusiasm and passion was clearly visible.
dotnetdays 2025 Sessionize Event Upcoming
.NET DeveloperDays 2024 Warsaw Sessionize Event
.NET Day Switzerland 2024 Sessionize Event
Techorama 2024 Belgium Sessionize Event
NDC Porto 2023 Sessionize Event
Techorama Netherlands 2023 Sessionize Event
KCDC 2023 Sessionize Event
DOTNED SATURDAY 2023 Sessionize Event
Techorama Netherlands 2022 Sessionize Event
NDC Oslo 2022 Sessionize Event
Developer Week '22 Sessionize Event
Future Tech 2022 Sessionize Event
DOTNED SATURDAY 2022 Sessionize Event
.NET Developer Conference '21 Sessionize Event
Please note that Sessionize is not responsible for the accuracy or validity of the data provided by speakers. If you suspect this profile to be fake or spam, please let us know.
Jump to top