Service discovery is a crucial aspect of microservices architecture that enables services to find and communicate with each other efficiently. In a dynamic environment where services are frequently added, removed, or scaled, service discovery automates the process of locating service instances, promoting seamless interaction and reducing latency. Below are three diverse, practical examples of service discovery in microservices, showcasing different approaches and tools.
In a microservices architecture, managing multiple services can become cumbersome. Netflix’s Eureka is a service registry that helps manage this complexity by allowing services to register themselves and discover other services easily.
Service Registration: When a new instance of a microservice, such as an Order Service, starts, it registers itself with the Eureka server.
@SpringBootApplication
public class OrderService {
    public static void main(String[] args) {
        SpringApplication.run(OrderService.class, args);
    }
}
In the application properties, include:
eureka.client.serviceUrl.defaultZone=http://localhost:8761/eureka/
spring.application.name=order-service
Service Discovery: Other microservices, like the Inventory Service, can find the Order Service by querying the Eureka server.
@RestController
public class InventoryController {
    @Autowired
    private DiscoveryClient discoveryClient;
    @GetMapping("/order-service-url")
    public String getOrderServiceUrl() {
        List<String> instances = discoveryClient.getServices();
        return instances.toString();
    }
}
Consul is a tool for service discovery, configuration, and orchestration. It provides a distributed, highly available service registry that is suitable for dynamic microservices environments.
Service Registration: When the Auth Service starts, it registers with Consul using a simple HTTP API call.
curl -X PUT -d 'healthy' http://localhost:8500/v1/agent/service/register -d '{"ID":"auth-service","Name":"Auth","Address":"127.0.0.1","Port":8081}'
Service Discovery: When the User Service needs to authenticate a user, it queries Consul to find the Auth Service’s address.
curl http://localhost:8500/v1/catalog/service/Auth
This returns the service details:
[{"ServiceID":"auth-service","ServiceName":"Auth","Address":"127.0.0.1","Port":8081}]
Kubernetes, a popular container orchestration platform, provides native service discovery through its DNS system, allowing seamless communication between services.
Service Definition: Define a Service resource in Kubernetes for a Payment Service.
apiVersion: v1
kind: Service
metadata:
  name: payment-service
spec:
  selector:
    app: payment
  ports:
    - protocol: TCP
      port: 80
      targetPort: 8080
Service Discovery: Other services can access the Payment Service using its DNS name.
curl http://payment-service.default.svc.cluster.local
This will route the request to one of the available Payment Service pods.
By implementing these service discovery strategies, microservices can communicate effectively, improving system reliability and scalability.