Integration of Microservices
What is microservice
- is relatively small
- can be developed and deployed independently
- Ideally, each service should have only a small set of responsibilities (SRP)
- Opposite to monolithic application
MOSi, POSi, Weather API, Warning text service, ....
Monolith is evil and only right way is microservice, which is one process written in any language.
Monolith advantages
- One change in one commit
- Easier to test functionality
- No compatibility issues and dependencies
- Deployment and rollback is simple
Integration
- Direct client-to-microservice communication
- API Gateway (Facade)
- Service discovery
- Database per service
- Events sourcing
- Deployment
Direct client to microservice communication
Pro
- Easy to implement
Cons
- Only HTTP protocol
- Too many connections - slow
- Difficult to refactor microservices - merging, splitting
API Gateway
Pros
- encapsulate internal structure
- simplify client code
- auth, cache
Cons
- another component
- development bottleneck
Types
- One for all clients
- One for mobile, one for desktop, one for web
MeteoGroup
- RoadMaster - Backed for Frontend
- Weather API (access to MOSi, POSi)
Service discovery
- Client side service discovery
Service Discovery
Client
Service
- Server side service discovery
Service Discovery
Load Balancer
Service
Client
Service discovery in MG
Service Discovery
(Consul)
Load Balancer
Service A
Client
Service A
manifest.toml
manifest.toml
Database per service
Service A
Database
MySQL
Service B
Database
MongoDB
Pros
- Loosely coupled
- Best suited database for every service
Cons
- Business transactions are harder to implement
- Joining data is challenging
- Complexity - managing SQL and NonSQL databases
"Database per service" doesn't mean a database SERVER per service
Event sourcing
Rather than persisting an object in its current state, event sourcing instead writes an immutable log of deltas (domain events) to the database
App
Event
Event
Event Store
Materialized View
Event
Event
External
Systems
Deployment
Multiple services per Host
Service per Host
Host
Service A
Service B
Service C
Service per VM
VM
Service A
VM
Service B
Service per Container
Container
Service A
Container
Service B
Host
Deployment in MG
Service per Container
Container
Service A
Container
Service A
Docker Host
Container
Service B
-
Marathon
- Check app (running, stopped)
-
Grafana
- Check resources (cpu, memory, ...)
-
Kibana
- Check application logs
Q&A
deck
By Milan Hradil
deck
- 499