Finding harmony in Microservices: Choreography vs Orchestration

When designing complex systems, especially those involving microservices and distributed environments, you often get to the point where you have to design a way to get different services to collaborate, to work together to accomplish some kind of workflow. For example, let’s think about an order in an e-commerce system: we might have several services involved, such as warehouse, payment, shipping, just to name a few. Often these services are implemented in stand-alone microservices, which must somehow act together and synchronize in order to properly fulfill the order....

December 7, 2024 · 4 min · Alessio Debernardi Venon

Git merge vs git rebase

Anyone who has worked with Git at least once faced the dilemma of choosing between git merge (merging) and git rebase (rebasing). Both commands are used to integrate changes from one branch into another, but they do it in fundamentally different ways and have different use cases, both with their own pros and cons. Let’s try to understand how they work and the differences between them. Git Merge The merge command integrates changes from one branch into another by creating a new commit (called merge commit) that combines the changes from the source branch with the target branch....

October 31, 2024 · 6 min · Alessio Debernardi Venon

N+1 problem

What is the N+1 problem? In software engineering, and more specifically in database management and ORM (Object-Relational Mapping) frameworks, the N+1 query problem is a common performance issue generated by non-optimized query design. This problem can significantly degrade the performance of applications, leading to increased load times and increased resources used by the database. The N+1 query problem occurs when an application needs to retrieve related data from a database: instead of fetching all the required data in a single query, the application runs one initial query to retrieve a list of items (the “1” query), and then runs additional queries for each item to retrieve the related data (the “N” queries), generating a total of N+1 queries....

July 9, 2024 · 4 min · Alessio Debernardi Venon

Domain Driven Design - A quick introduction

What is Domain Driven Design? Domain-driven design (DDD) is a software design approach that focuses on modeling software by matching a specific area of the business, called domain. In this approach, as the name suggest, the domain is the “center of gravity”, and everything else orbits around it. The domain is typically divided into subdomains, which are smaller, more focused areas of the domain. Let’s consider a hypothetical e-commerce application as an example:...

March 12, 2024 · 14 min · Alessio Debernardi Venon

Algorithm complexity

Algorithm complexity is a crucial concept in computer science that helps us analyze the efficiency of algorithms. Whether you’re a budding programmer or a seasoned developer, understanding algorithm complexity is essential for writing efficient and scalable code. In this blog post, we’ll explore the basics of algorithm complexity and guide you through the process of calculating it. What is Algorithm Complexity? Algorithm complexity is a measure of the efficiency of an algorithm in terms of the resources it consumes....

November 28, 2023 · 8 min · Alessio Debernardi Venon

Hexagonal (Ports and Adapters) Architecture

In the realm of software architecture, various design patterns and principles aim to enhance the flexibility, maintainability, and scalability of applications. One such pattern that has gained prominence is the Hexagonal Architecture, also known as Ports and Adapters. This architectural style, introduced by Alistair Cockburn in 2005, provides a clean separation between the core business logic of an application and its external dependencies, such as the user interface, database, and external systems....

November 12, 2023 · 7 min · Alessio Debernardi Venon

Trunk-based development - TBD

Trunk-based development (TBD) is a software development workflow that emphasizes frequent, small commits to a single codebase branch, called trunk or main branch. In TBD, developers works and push their changes directly into the trunk branch, or create short-lived feature branches that are merged back into the trunk frequently. This helps to keep the trunk branch up-to-date and ready for deployment at any time. This is in contrast with other branching models, such as Git Flow, which uses multiple long-lived branches for different purposes (such as development/staging/production and releases)....

October 30, 2023 · 3 min · Alessio Debernardi Venon

Basics of OOP design - SOLID principles

SOLID is an acronym for five object-oriented design principles used to design software that is robust, testable, extensible, and maintainable. These design principles are: Single Responsibility Principle (SRP) Open-closed Principle (OCP) Liskov substitution principle (LSP) Interface segregation principle (ISP) Dependency inversion principle (DIP) Single Responsibility Principle (SRP) A class should have one, and only one, reason to change Each module should perform a single task or function, and should be responsible for that task only....

October 2, 2023 · 9 min · Alessio Debernardi Venon