The client-side discovery pattern

Pragya Keshap answered on February 18, 2023 Popularity 2/10 Helpfulness 1/10

Contents


More Related Answers

  • Using DiscoveryClient
  • Enable discovery client
  • client-side-discovery
  • Service Registry/Discovery Pattern
  • What is Service Discovery Pattern?
  • The server-side discovery pattern

  • The client-side discovery pattern

    0

    In a microservice-based application, services need to communicate with one another to carry out a business task. In a monolithic application, communication between services is very easy, because all services are typically part of the same application. However, in a distributed system, the services are not part of the same application. Instead, services run on separate, independent virtual machines or containers. These have well-known locations (hosts and ports), that change if the application is scaled up or down. This is where service discovery comes in.

    In client-side discovery, a client service finds the location of other service instances by querying a Service Registry. The client is also responsible for managing load balancing requests across services. The Service Registry is a database for microservice instances. On the client side, we have to use an algorithm to select one of the available instances using a few parameters.

    The following diagram illustrates the client-side service discovery pattern:

    As you can see, the client service itself registers with the registry server. Other microservices also register with the same registry server. All instances of services are registered with the specific location on the registry server. The client service uses the service name with which it is registered, and is removed from the Service Registry when the instance terminates. The service instance's registration is typically refreshed periodically using a heartbeat mechanism.

    This service discovery pattern has various advantages and disadvantages. The advantages are as follows:

    This pattern is very simple and straightforward because there are no moving parts related to the distributed application, except the registry server

    You can apply more intelligence on the client side to make load balancing decisions

    The client-side discovery pattern also has the following disadvantages:

    This approach couples the client code with the registry server code

    You have to implement discovery logic for each service because the services may use different programming languages

    Netflix OSS provides a client‑side discovery pattern called Netflix Eureka. Netflix Eureka is a Service Registry that provides a REST API to manage service‑instance registration and send queries to available instances. Netflix also provides another component called Netflix Ribbon, which is an IPC client that works with Eureka to load balance requests across available service instances. We will discuss Eureka in more depth later.

    First, let's have a look at another approach: the server-side service discovery pattern.

    Popularity 2/10 Helpfulness 1/10 Language whatever
    Source: Grepper
    Link to this answer
    Share Copy Link
    Contributed on Feb 18 2023
    Pragya Keshap
    0 Answers  Avg Quality 2/10


    X

    Continue with Google

    By continuing, I agree that I have read and agree to Greppers's Terms of Service and Privacy Policy.
    X
    Grepper Account Login Required

    Oops, You will need to install Grepper and log-in to perform this action.