Load Balancer & Service RegistryAPI Gateway & BFF APIsSynchronous CommunicationAPI Style for microserviceResiliency PatternOpenAPI and API CatalogsAsynchronous CommunicationTransaction Manager for logical distributed transactionsEventual Consistency and Event-driven ArchitectureDeployment using virtual machinesDeployment using containersDeployment using cloudSecurityCentral LoggingCentral Monitoring
Load Balancer & Service Registry
data:image/s3,"s3://crabby-images/659cf/659cfa08d635f92284f8d6ea8f18e28b9a35b1ae" alt="notion image"
data:image/s3,"s3://crabby-images/49dce/49dce61c1954dada8504ab7daa0f1929ce098cfe" alt="notion image"
Â
Load balancers
- Support scalability by routing incoming traffic to a stateless service instance
- Upstream client is unaware of the load balancer
- Most promote availability and therefore resiliency using health probes and checks
- Health probes can work with custom health check endpoints
- Either provide or support service registry systems
- On-premise physical or software options, and managed options in the cloud
Â
Loading balancer routing method:
- Round Robin: Simplest type of routing, can result in uneven traffic
- Least Connections: Routes based on number of client connections to server, Useful for chat or streaming applications
- Least Response Time: Routes based on how quickly servers respond
- IP Hash: Routes client to server based on IP; Useful for stateful sessions
Â
Service registry
- Record and provide microservice instance locations
- Microservices register on startup and deregister on shutdown
- Used by traffic routing mechanisms like load balancers
- Develop your own or DNS on cloud PAAS solutions and container orchestration engines
data:image/s3,"s3://crabby-images/e5b33/e5b33813d121ffefe64bdf713be82a80c366618c" alt="notion image"
k8s: know the service name you want to talk to, it takes care of the routing traffic to the container.
API Gateway & BFF APIs
data:image/s3,"s3://crabby-images/7e872/7e87294b025886e328a5d6fc55a897d92bdbcd15" alt="notion image"
data:image/s3,"s3://crabby-images/e6f7e/e6f7eaff8d121e2958cbce44e00e822f60bd0598" alt="notion image"
data:image/s3,"s3://crabby-images/8e892/8e892920b36e95e2ada50a06d8c5cc5c739b7fff" alt="notion image"
Â
API gateway
- Central entry point, exposing microservices using one interface
- Can handle security: Authentication and authorization
- Can also provide call rate limiting, monitoring, caching, and logging
- Can provide load balancing and service registry functionality
Â
Backend for frontend API (a type of API gateway!)
- Central entry point, exposing microservices using one interface for a specific client
- Can handle security: Authentication and authorization
- You would use in addition to load balancers and service registry
- Custom logic to consolidate and format data from downstream microservices
Â
Both components decouple frontend applications from microservices
Avoid a monolith API gateway or monolith BFF API
Synchronous Communication
Challenges: a microservice talks to another.
data:image/s3,"s3://crabby-images/68fa9/68fa9aa52441ebc6332209dda3726dd7a5f37a5e" alt="notion image"
data:image/s3,"s3://crabby-images/2242b/2242badd741a1f5cbb80b1d79be6a355b304945d" alt="notion image"
Â
Request response communication
- Client to service, and service to service and service to external
- Your upstream software makes a request to a downstream software
- Upstream software waits for a response from the downstream software
Â
HTTP is the most used open communication protocol for this
- Huge compatibility across hardware and software thanks to its use on the Internet
- If you use the Internet, you are already using HTTP
Â
Microservice synchronous communication challenges
- Both parties must be available, and then you wait for a response
- Performance subject to network quality
- Client must know the location of the service (host/port)
- Reducing temporal coupling and avoiding distributed transactions
API Style for microservice
data:image/s3,"s3://crabby-images/b9c3a/b9c3ab9698083d8a544c56a54e36611a0e4fc393" alt="notion image"
data:image/s3,"s3://crabby-images/f8598/f8598e03fa9d93eeb1b12c85d188bb084c73ec30" alt="notion image"
Â
REST-full microservices are popular
- Consumer and developer-friendly by providing a predictable style
- REST principles are in line with microservices
- Decouples client and service
- Functionality to honor contracts (versioned endpoints for backwards compatibility)
- Encourage stateless services
- Ideal contract and data format for caching strategies
Â
Other styles are available and should be considered
- RPC, GRPC, SOAP, GraphQL and many more
Resiliency Pattern
- Timeout
- Circuit breaker: after a number of trials, break the connection and return error
data:image/s3,"s3://crabby-images/210b1/210b17f19cab71f1b552f81db64a08275368945d" alt="notion image"
- Retry
data:image/s3,"s3://crabby-images/79230/792300da66e1352c9938a021e11ab1b95b52ce43" alt="notion image"
- Cache
data:image/s3,"s3://crabby-images/f1dc8/f1dc85b74dee92b5eeec607887ca287c5d3d0359" alt="notion image"
Â
Timeout pattern
- Configure short timeouts on calling code to avoid waiting forever for a response
Â
Circuit Breaker pattern: Use to fail fast and return an error instantly
- Calling code stops calling downstream services if too many failures occur
- Calling of downstream service resumes after a specified threshold
Â
Retry pattern
- Ideal for transient faults: Momentary loss of connectivity or service
- Limit the number of retries and use with the circuit breaker pattern
Â
Caching Strategy
- Separate cache database serving microservice instances
- Serve matching data from a cache that hasn't expired instead of making a sync call
Â
Asynchronous communication using message brokers
OpenAPI and API Catalogs
Swagger
Â
OpenAPI
- Document your microservice contracts (endpoints)
- Document using machine readable format (JSON)
- Use document to generate interactive websites
- Create an API catalogue
- Use machine readable documentation with many other tools
Â
Useful for communicating contracts, data, and functionality
- Development teams working on microservices concurrently
- Business teams needing to see the data
- Scoping and designing new parts of your architecture
Asynchronous Communication
Message Broker
data:image/s3,"s3://crabby-images/9352b/9352bd42ab88597f911a66005699696d1ab8bd80" alt="notion image"
data:image/s3,"s3://crabby-images/dbf2c/dbf2ca3b3d37a76a905683e97088a67ce6f95550" alt="notion image"
Asynchronous communication: Fire and forget and return to the caller
- Decouples client and service and reduces sync com and temporal coupling
Â
Messaging system / Message Broker / Service Bus / Event Bus
- Sender also can be called client and publisher
- Many queues with many listeners to send and receive data
- Data sent referred to has as a message (command) or event
- Many queueing patterns
- Message brokers provide resiliency in your architecture
Â
Asynchronous communication and messaging systems required for
- Event-driven architecture and eventual-consistency
- Both concepts are helpful for microservices architecture
Managing a logical distributed transaction (next section!)
Transaction Manager for logical distributed transactions
data:image/s3,"s3://crabby-images/7dfe1/7dfe180bd2cc1dd4754b87b27339d49b7e176d0c" alt="notion image"
Avoiding physical distributed transactions
- We can avoid physical distributed transactions in terms of waiting
- Avoided using asynchronous communication and messaging systems
Â
Managing the logical distributed transactions
- We need to manage the state of a logical data transaction (saga pattern)
- Centralize the transaction state: Somewhere, we can see that state of each part
- Have failure compensation: Functionality to undo a partially complete transaction
- Transaction managers and the saga pattern also allow you to cancel a transaction
Eventual Consistency and Event-driven Architecture
Instead of calling 2 microservices, whenever a product updates, it will publish the product info into a message broker. Our inventory microservice then subscribes to that information and keeps a local copy of all the product names in its local database.
Advantage of this approach: performance, decoupled.
data:image/s3,"s3://crabby-images/5f1c7/5f1c7e22b914996b7207840a3c032127182b0bc2" alt="notion image"
data:image/s3,"s3://crabby-images/2e3aa/2e3aa6c21787e448b5097623e5e8e3cd21d316b8" alt="notion image"
Duplicating data for performance
- A microservice has a local copy of data belonging to another service
- Local copy avoids having to make a sync call to retrieve the data from the source
Â
Eventual Consistency
- Uses publisher and subscriber model: Where client and service completely decoupled
- Microservice that owns the data publishes data changes as events (messages)
- Subscribers interested in the data subscribe to the events (optionally store them locally)
- This duplicated data across our microservices is eventual consistent
- Many eventual consistency patterns that balance availability and consistency
Â
Event-Driven Architecture
- Complete decoupling of publisher and subscriber: Publish data changes as events
- Create new subscribers, i.e., new use cases for your data without changing publishers
Deployment using virtual machines
Why not physical machines?
- Waste of hardware resources (CPU, Memory, and storage)
- Multiple services on one machine violates the autonomous principle
- Also violates the resiliency principle (scalability and availability)
Â
Virtual machines
- Better resource utilization (CPU, Memory, and storage)
- Templating virtual machine images and snapshot backups
- Each service instance on a small VM promotes design principles
- Support for AC (Infrastructure as code)
- Special VM operating systems to manage VM's
- Multiple services still venerable to host failures
- Each VM still has an unnecessarily large footprint and are slow to startup
Deployment using containers
Containers are a type of virtualization
- Like VMs, isolate services from each other
- Single service per container (single deployable unit containing all dependencies)
- Much more resource-efficient and startup faster than VMs
- Most popular way of deploying microservices
Simplify the running of complex microservices architecture and dependencies
- Multiple container images containing microservices architecture run using one file
- Recreate full microservices architecture environments (Spin up production on dev)
Â
Container orchestration engines
- Managing multiple containers on multiple servers: Load balancing and discovery
- Run containers: Ensure numbers and availability across these servers
- Containers without an orchestration engine are not ideal!
- Well supported on cloud platforms and on-premise
Deployment using cloud
Why not on-premise?
- Only if you already have the budget, teams, and location/equipment
- Cloud provides managed and serverless services
Â
IAAS: Deploy to virtual machines/containers within the cloud
- Infrastructure as a service: When you still need to manage the OS/Runtime
- You still must manage and update the OS and runtime
Â
PAAS: Deploy microservice to cloud-specific Blackbox
- Managing applications/services and data only
- No control over the runtime/OS running the application
Â
FAAS: Serverless functions: Deploy code, i.e., functions instead of applications
- Cloud platform handles the running, concurrency, and resources
- Cloud platform may limit concurrency, duration of running, and tech choices
Security
data:image/s3,"s3://crabby-images/ae288/ae2883a6d82e18d969a130e097fe9581bdaa8d47" alt="notion image"
data:image/s3,"s3://crabby-images/76676/76676ab01fcde2127cf8f70db72a246507c14e44" alt="notion image"
- Use HTTPS everywhere!
- Network security: private and public network
- Call rate-limiting at API Gateway or BFF API level
- Use a reputable Identity provider/service
- OAuth2 and OpenID Connect standards
- Authentication: Identify the user (Identity token)
- Authorization: Can the client app access the microservice? (access token)
- Authorization: What can the user do? (access token)
- Pass these tokens between clients and services: all services validate tokens
- Standards: OAuth2, OpenID connect, and Token exchange
- Identity providers: Azure AD, Okta, Pingldentity, IdentityServer, and many more!
- Secure message broker using HTTPS, authentication, and message validation
Central Logging
Central logging Solutions
- Reputable product that supports scalability and availability
- Centralized portal for querying, filtering, and managing log data
- Managing data: Archiving and backing up log data
- Security: secure connections (HTTPS), authentication, and authorization
- Examples: Elastic/Kibana, Splunk, and Graphite
Â
Logging library
- Structured logging: Support for custom fields, logging levels, and correlation IDs
- Lightweight log data format like JSON
Â
Ensuring logging data and logging database are compliant
- Data compliance requlations
- Communicate data policy
Â
Cross-cutting concern for Architects to standardize
Central Monitoring
Centralized monitoring tool
- Real-time metrics across servers
- Visualize and aggregate data
- Vast alerting options: SMS, email, visual and custom calls!
- Examples: Nagios, PRTG, and New Relic
- Archiving and backup of data
Â
Monitoring library
- Custom or off-shelf library for consistent stats across architecture
- Preconfigured machine, VM, or container templates
Â
Cross-cutting concern for Architects to standardize
Â