Is a “hybrid” of the microservices architecture style. It’s very pragmatic, flexible, but has one of the lowest complexity and cost of all distributed architecture style, making it a popular choice for business-related applications.
Basic topology of service-based architecture follows a distributed macro layered structure, consisting of a separately deployed user interface, distinct services, and a monolithic database. Services in this architecture are usually “domain services”, covering a specific part of the general domain. All services are independent and separately deployed.
As a shared database is used, the number of services within an application context are generally between 4 and 12, averaging at 7 services.
Communication between the UI and the components usually are REST, RPC, SOAP, or messaging busses. Generally the user interface access the services directly using a service locater pattern, API Gateway, or Proxy.
Due to the relative small amount of services, the DB connections are often not a bottleneck. Making changes however comes with challenges.
This is a flexible architecture style, therefore many variants exist.
These variants show that with this flexibility, one can design for scalability, fault tolerance, and security, by putting a specific database in a non public network.
In the Service Based Architecture style, all business logic is carefully located in a business domain, related to that domain. Therefore, a single (domain) service can use the ACID transaction properties for implementing any logic. Notice therefore, why in service based, interservice communication should be prohibited at all costs.
Microservice Style allows interservice communication, meaning, that you loose the ACID transaction properties and depend on sagas and the BASE transaction properties. In Service based a single domain service would be responsible for example, an order, this OrderService would be responsible for the order, but also the payment and many other relevant responsibilities. In microservice style, these responsibilities would be most likely spread across multiple services.
Due to the limitation of no interservice communication, services are more “coarse-grained”, meaning they take on more responsibility, are less “Specialized” and there might be duplication in functionality to avoid having to rely on interservice communication.
As multiple services depend on the same, central, monolith database, it will be challenging to make changes to the databases while not causing problems for other services. Proper database partitioning is not mandatory, but can be of great help to mitigate some off these challenges.
In many languages you might have some “single shared library” with all the database entities that exist in your database. If one schema changes, this “single shared library” is updated, which causes ALL the domain services to be modified/affected. Hence, with logical portioning, you can have shared entity libraries and libraries per service domain, which decreases the impact of a single change to the database schema.
Important to read the Difference with Microservice Architecture Style note.
This is a lighter approach to microservice architecture style. It imposes some limits, it makes your services bigger, but you can work with plan old ACID transactions. Due to the imposed limitations, you take a lot of complexity of the table, which can be a key advantage. Working with fine-grained services comes with a whole set of challenges, which you might not want to tackle, or neither can afford their cost.
You have a distributed style, but transactions are contained within a single domain service, yet having high modularity and many other distributed advantages. You won’t have to deal with “orchestration” or “choreography” for transactions across various fine grained services.
Characteristic | Rating |
---|---|
Partitioning Type | Domain |
Number of quanta | 1 to many |
Deployability | ⭐⭐⭐⭐ |
Elasticity | ⭐⭐ |
Evolutionary | ⭐⭐⭐ |
Fault Tolerance | ⭐⭐⭐⭐ |
Modularity | ⭐⭐⭐⭐ |
Overall cost | ⭐⭐⭐⭐ |
Performance | ⭐⭐⭐ |
Reliability | ⭐⭐⭐⭐ |
Scalability | ⭐⭐⭐ |
Simplicity | ⭐⭐⭐ |
Testability | ⭐⭐⭐⭐ |
None