Communication between microservices - request data

后端 未结 3 1131
余生分开走
余生分开走 2021-02-13 21:37

I am dealing with communication between microservices.

For example (fictive example, just for the illustration):

  • Microservice A - Store Us
3条回答
  •  走了就别回头了
    2021-02-13 21:58

    It all depends on your service's communication behaviour to choose between REST APIs and Event-Based design Or Both.

    What you do is based on your requirement you can choose REST APIs where you see synchronous behaviour between services and go with Event based design where you find services needs asynchronous behaviour, there is no harm combining both also.

    Ideally for inter-process communication protocol it is better to go with messaging and for client-service REST APIs are best fitted. Check the Communication style in microservices.io

    REST based Architecture

    • Advantage

      1. Request/Response is easy and best fitted when you need synchronous environments.

      2. Simpler system since there in no intermediate broker

      3. Promotes orchestration i.e Service can take action based on response of other service.

    • Drawback

      1. Services needs to discover locations of service instances.

      2. One to one Mapping between services.

      3. Rest used HTTP which is general purpose protocol built on top of TCP/IP which adds enormous amount of overhead when using it to pass messages.

    Event Driven Architecture

    • Advantage

      1. Event-driven architectures are appealing to API developers because they function very well in asynchronous environments.

      2. Loose coupling since it decouples services as on a event of once service multiple services can take action based on application requirement. it is easy to plug-in any new consumer to producer.

      3. Improved availability since the message broker buffers messages until the consumer is able to process them.

    • Drawback

      1. Additional complexity of message broker, which must be highly available
      2. Debugging an event request is not that easy.

提交回复
热议问题