Skip to content

Latest commit

 

History

History
95 lines (82 loc) · 7.26 KB

microservices.md

File metadata and controls

95 lines (82 loc) · 7.26 KB

Microservices

What are the possible ways for communication between microservices?

  • Synchronous protocol. HTTP is a synchronous protocol. The client sends a request and waits for a response from the service. That's independent of the client code execution that could be synchronous (thread is blocked) or asynchronous (thread isn't blocked, and the response will reach a callback eventually). The important point here is that the protocol (HTTP/HTTPS) is synchronous and the client code can only continue its task when it receives the HTTP server response.
  • Asynchronous protocol. Other protocols like AMQP (a protocol supported by many operating systems and cloud environments) use asynchronous messages. The client code or message sender usually doesn't wait for a response. It just sends the message as when sending a message to a RabbitMQ queue or any other message broker.
Relative links:

What is exchange in message queue?

Exchange: a queue aggregator that abstract away message queues and routes messages to the appropriate queue based on some predefined logic.

Relative links:

What are the benefits of microservices?

  • Technology Heterogeneity
  • Resilience
  • Scaling
  • Ease of Deployment
  • Organizational Alignment
  • Composability
  • Optimizing for Replaceability
Relative links:

What are the disadvantages of microservices?

  • Microservices Are More Complex
  • Microservices Require Cultural Changes
  • Microservices Are More Expensive
  • Microservices Pose Security Challenges
Relative links:

https://www.tiempodev.com/blog/disadvantages-of-a-microservices-architecture/

What are the possible issues in microservices

  1. As if monitoring a monolith wasn’t hard enough
  2. Logging is distributed between services
  3. An issue that’s caused by one service, can cause trouble elsewhere
  4. Finding the root cause of problems
  5. Version management and cyclic dependencies between services
Relative links:

What are the possible solutions for the case when one service is not available?

  1. The circuit breaker pattern is the solution to this problem. The basic idea behind the circuit breaker is very simple. You wrap a protected function call in a circuit breaker object, which monitors for failures. Once the failures reach a certain threshold, the circuit breaker trips, and all further calls to the circuit breaker return with an error or with some alternative service or default message, without the protected call being made at all. This will make sure system is responsive and threads are not waiting for an unresponsive call.
  2. Retry Logic
Relative links:

What is the difference between synchronous and asynchronous communication?

  • Synchronous protocol. HTTP is a synchronous protocol. The client sends a request and waits for a response from the service. That's independent of the client code execution that could be synchronous (thread is blocked) or asynchronous (thread isn't blocked, and the response will reach a callback eventually). The important point here is that the protocol (HTTP/HTTPS) is synchronous and the client code can only continue its task when it receives the HTTP server response.
  • Asynchronous protocol. Other protocols like AMQP (a protocol supported by many operating systems and cloud environments) use asynchronous messages. The client code or message sender usually doesn't wait for a response. It just sends the message as when sending a message to a RabbitMQ queue or any other message broker.
Relative links:

https://docs.microsoft.com/en-us/dotnet/architecture/microservices/architect-microservice-container-applications/communication-in-microservice-architecture

What are possible ways for implementing authentication in microservices?

  1. Distributed Session Management
  2. Client Token
  3. Single sign-on
  4. Client Token with API Gateway
  5. Third-party application access
  6. Mutual Authentication
Relative links:

What is Eventual consistency?

Rather than ensuring that the system is in a consistent state all the time, instead we can accept that the system will get it at some point in the future. This approach is especially useful for long-living business operations.

Relative links:

How different types of communication can influence on performance?

You should prefer asynchronous communication for all remote calls. They don’t block any resources while you’re waiting for the response and you can even execute multiple calls in parallel. That can provide huge performance improvements because you just need to wait until the slowest service answered your request.

As always, there are several ways to implement an asynchronous communication between two services. One of them is an asynchronous REST call.

Relative links:

What are possible strategies and issues in microservices deployment?

Relative links:

Home Page