Service Discovery is one of the key tenets of a microservice-based architecture. Trying to hand-configure each client or some form of convention can be difficult to do and can be brittle. Eureka is the Netflix Service Discovery Server and Client. The server can be configured and deployed to be highly available, with each server replicating state about the registered services to the others.
In this post, I will cover the common uses of the Spring Cloud Netflix Eureka. This post is based on Java 21, Spring Boot 3.5.3, and Spring Cloud 2025.0.0.
Next, I will use several simple example applications to show it in action.
Eureka Server 1. Create Project and Add Dependencies Using Gradle 1. Create a Java application with the gradle init command.
$ mkdir  spring-cloud-eureka-server && cd  spring-cloud-eureka-server $ gradle --configuration-cache \     init --use-defaults \     --type  java-application \     --package com.taogen.springcloud 
2. Gradle configuration
app/build.gradle.kts
plugins {     java     id("org.springframework.boot" ) version "3.5.3"           id("io.spring.dependency-management" ) version "1.1.7"  } extra["springCloudVersion" ] = "2025.0.0"  java {     toolchain {         languageVersion = JavaLanguageVersion.of(21 )     } } repositories {     mavenCentral() } dependencies {     implementation("org.springframework.cloud:spring-cloud-starter-netflix-eureka-server" )     testImplementation("org.springframework.boot:spring-boot-starter-test" )     testRuntimeOnly("org.junit.platform:junit-platform-launcher" ) } dependencyManagement {     imports {         mavenBom("org.springframework.cloud:spring-cloud-dependencies:${property("springCloudVersion" )} " )     } } tasks.withType<Test> {     useJUnitPlatform() } 
Using Maven 1. Create a Java application with mvn command.
$ mvn -B archetype:generate \     -DgroupId=com.taogen.springcloud \     -DartifactId=spring-cloud-eureka-server \     -DarchetypeArtifactId=maven-archetype-quickstart \     -DarchetypeVersion=1.5 
2. Maven configuration
pom.xml
<?xml version="1.0"  encoding="UTF-8" ?> <project  xmlns ="http://maven.apache.org/POM/4.0.0"  xmlns:xsi ="http://www.w3.org/2001/XMLSchema-instance"           xsi:schemaLocation ="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" >     <modelVersion > 4.0.0</modelVersion >      <groupId > com.taogen.springcloud</groupId >      <artifactId > spring-cloud-eureka-server</artifactId >      <version > 1.0-SNAPSHOT</version >      <name > spring-cloud-eureka-server</name >      <properties >          <project.build.sourceEncoding > UTF-8</project.build.sourceEncoding >          <maven.compiler.release > 21</maven.compiler.release >          <java.version > 21</java.version >          <spring-boot.version > 3.5.3</spring-boot.version >          <spring-cloud.version > 2025.0.0</spring-cloud.version >      </properties >      <dependencies >          <dependency >              <groupId > org.springframework.cloud</groupId >              <artifactId > spring-cloud-starter-netflix-eureka-server</artifactId >          </dependency >          <dependency >              <groupId > org.springframework.boot</groupId >              <artifactId > spring-boot-starter-test</artifactId >              <scope > test</scope >          </dependency >      </dependencies >      <dependencyManagement >          <dependencies >              <dependency >                  <groupId > org.springframework.cloud</groupId >                  <artifactId > spring-cloud-dependencies</artifactId >                  <version > ${spring-cloud.version}</version >                  <type > pom</type >                  <scope > import</scope >              </dependency >              <dependency >                  <groupId > org.springframework.boot</groupId >                  <artifactId > spring-boot-dependencies</artifactId >                  <version > ${spring-boot.version}</version >                  <type > pom</type >                  <scope > import</scope >              </dependency >          </dependencies >      </dependencyManagement >      <build >          <plugins >              <plugin >                  <groupId > org.springframework.boot</groupId >                  <artifactId > spring-boot-maven-plugin</artifactId >              </plugin >          </plugins >      </build >  </project > 
Using Spring Initializr Go to https://start.spring.io/ 
Project Metadata
Group: com.taogen.springcloud 
Artifact: spring-cloud-eureka-server 
 
Add dependencies
2. Spring Configuration The spring configuration mainly contains Eureka server configurations.
application.yml
spring:   application:      name:  eureka-server    freemarker:      template-loader-path:  classpath:/templates/      prefer-file-system-access:  false  server:      port:  8761  eureka:   instance:      hostname:  localhost    client:           registerWithEureka:  false           fetchRegistry:  false           serviceUrl:        defaultZone:  http://${eureka.instance.hostname}:${server.port}/eureka/    server:           waitTimeInMsWhenSyncEmpty:  5  
3. Eureka Server Application EurekaServerApplication.java
package  com.taogen.springcloud;import  org.springframework.boot.SpringApplication;import  org.springframework.boot.autoconfigure.SpringBootApplication;import  org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;@SpringBootApplication @EnableEurekaServer public  class  EurekaServerApplication  {    public  static  void  main (String[] args)  {         SpringApplication.run(EurekaServerApplication.class, args);     } } 
4. Start and Verification Starting Spring Cloud Eureka Server 
Running the main() method in the EurekaServerApplication to start Spring Cloud Eureka Server.
Verification 
Visiting http://localhost:8761/  to see the dashboard web page of Eureka Server.
Eureka Client 1. Create Project and Add Dependencies Using Gradle 1. Create a Java application with the gradle init command.
$ mkdir  spring-cloud-eureka-client && cd  spring-cloud-eureka-client $ gradle --configuration-cache \     init --use-defaults \     --type  java-application \     --package com.taogen.springcloud 
2. Gradle configuration
app/build.gradle.kts
plugins {     java     id("org.springframework.boot" ) version "3.5.3"           id("io.spring.dependency-management" ) version "1.1.7"  } extra["springCloudVersion" ] = "2025.0.0"  java {     toolchain {         languageVersion = JavaLanguageVersion.of(21 )     } } repositories {     mavenCentral() } dependencies {     implementation("org.springframework.cloud:spring-cloud-starter-netflix-eureka-client" )     implementation("org.springframework.boot:spring-boot-starter-web" )     implementation("org.springframework.boot:spring-boot-starter-actuator" )     testImplementation("org.springframework.boot:spring-boot-starter-test" )     testRuntimeOnly("org.junit.platform:junit-platform-launcher" ) } dependencyManagement {     imports {         mavenBom("org.springframework.cloud:spring-cloud-dependencies:${property("springCloudVersion" )} " )     } } tasks.withType<Test> {     useJUnitPlatform() } 
Using Maven 1. Create a Java application with mvn command.
$ mvn -B archetype:generate \     -DgroupId=com.taogen.springcloud \     -DartifactId=spring-cloud-eureka-client \     -DarchetypeArtifactId=maven-archetype-quickstart \     -DarchetypeVersion=1.5 
2. Maven configuration
pom.xml
<?xml version="1.0"  encoding="UTF-8" ?> <project  xmlns ="http://maven.apache.org/POM/4.0.0"  xmlns:xsi ="http://www.w3.org/2001/XMLSchema-instance"           xsi:schemaLocation ="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" >     <modelVersion > 4.0.0</modelVersion >      <groupId > com.taogen.springcloud</groupId >      <artifactId > spring-cloud-eureka-client</artifactId >      <version > 1.0-SNAPSHOT</version >      <name > spring-cloud-eureka-client</name >      <properties >          <project.build.sourceEncoding > UTF-8</project.build.sourceEncoding >          <maven.compiler.release > 21</maven.compiler.release >          <java.version > 21</java.version >          <spring-boot.version > 3.5.3</spring-boot.version >          <spring-cloud.version > 2025.0.0</spring-cloud.version >      </properties >      <dependencies >          <dependency >              <groupId > org.springframework.cloud</groupId >              <artifactId > spring-cloud-starter-netflix-eureka-client</artifactId >          </dependency >          <dependency >              <groupId > org.springframework.boot</groupId >              <artifactId > spring-boot-starter-web</artifactId >          </dependency >          <dependency >              <groupId > org.springframework.boot</groupId >              <artifactId > spring-boot-starter-actuator</artifactId >          </dependency >          <dependency >              <groupId > org.springframework.boot</groupId >              <artifactId > spring-boot-starter-test</artifactId >              <scope > test</scope >          </dependency >      </dependencies >      <dependencyManagement >          <dependencies >              <dependency >                  <groupId > org.springframework.cloud</groupId >                  <artifactId > spring-cloud-dependencies</artifactId >                  <version > ${spring-cloud.version}</version >                  <type > pom</type >                  <scope > import</scope >              </dependency >              <dependency >                  <groupId > org.springframework.boot</groupId >                  <artifactId > spring-boot-dependencies</artifactId >                  <version > ${spring-boot.version}</version >                  <type > pom</type >                  <scope > import</scope >              </dependency >          </dependencies >      </dependencyManagement >      <build >          <plugins >              <plugin >                  <groupId > org.springframework.boot</groupId >                  <artifactId > spring-boot-maven-plugin</artifactId >              </plugin >          </plugins >      </build >  </project > 
Using Spring Initializr Go to https://start.spring.io/ 
Project Metadata
Group: com.taogen.springcloud 
Artifact: spring-cloud-eureka-client 
 
Add dependencies
Eureka Discovery Client 
Spring Web 
Spring Boot Actuator 
 
2. Spring Configuration The spring configuration mainly contains Eureka client configurations.
application.yml
spring:   application:      name:  eureka-client  server:      port:  0  eureka:   instance:      preferIpAddress:  true      instanceId:  ${spring.application.name}:${vcap.application.instance_id:${spring.application.instance_id:${random.value}}}    client:      registerWithEureka:  true      fetchRegistry:  true      serviceUrl:        defaultZone:  http://localhost:8761/eureka/      healthcheck:        enabled:  true  management:   endpoints:      web:        exposure:          include:  health,info,beans  
3. Eureka Client Application EurekaClientApplication.java
package  com.taogen.springcloud;     import  org.springframework.boot.SpringApplication;  import  org.springframework.boot.autoconfigure.SpringBootApplication;     @SpringBootApplication   public  class  EurekaClientApplication  {      public  static  void  main (String[] args)  {           SpringApplication.run(EurekaClientApplication.class, args);       }   } 
4. Start and Verification Starting Spring Cloud Eureka Client 
Running the main() method in the EurekaClientApplication to start Spring Cloud Eureka Client.
Verification 
Visiting the Eureka server dashboard page http://localhost:8761/  to see whether the Eureka client is registered in the Eureka server.
5. Using the EurekaClient Once you have an application that is a discovery client, you can use it to discover service instances from the Eureka Server. 
One way to do so is to use the native com.netflix.discovery.EurekaClient.
For example, Call the eureka-client-2 application’s /greeting endpoint from Eureka client 1:
@Autowired private  EurekaClient eurekaClient;@GetMapping("/callEurekaClient2") public  String callEurekaClient2 ()  {	InstanceInfo  instance  =  eurekaClient.getNextServerFromEureka("EUREKA-CLIENT-2" , false ); 	String  homePageUrl  =  instance.getHomePageUrl(); 	System.out.println("Home Page URL: "  + homePageUrl); 	ResponseEntity<String> response = restTemplate.getForEntity(homePageUrl + "/greeting" , String.class); 	System.out.println(response.getBody()); 	return  response.getBody(); } 
Using Spring DiscoveryClient
@Autowired private  DiscoveryClient discoveryClient;@GetMapping("/callEurekaClient2") public  String callEurekaClient2 ()  {	String  serviceId  =  "EUREKA-CLIENT-2" ; 	String  serviceUrl  =  discoveryClient.getInstances(serviceId).get(0 ).getUri().toString(); 	ResponseEntity<String> response = restTemplate.getForEntity(serviceUrl + "/greeting" , String.class); 	System.out.println(response.getBody()); 	return  response.getBody(); } 
Peer Awareness Eureka can be made even more resilient and available by running multiple instances and asking them to register with each other.
Eureka Server 
1. Set basic Eureka server configurations in application.yml
spring:   application:      name:  eureka-server    freemarker:      template-loader-path:  classpath:/templates/      prefer-file-system-access:  false  eureka:   client:           registerWithEureka:  false           fetchRegistry:  false    server:           waitTimeInMsWhenSyncEmpty:  5  
2. Eureka server peer configurations
application-peer1.yml
server:   port:  8763  eureka:   instance:      hostname:  peer3    client:      serviceUrl:        defaultZone:  http://peer1:8761/eureka/,http://peer2:8762/eureka/  
application-peer2.yml
server:   port:  8762  eureka:   instance:      hostname:  peer2    client:      serviceUrl:        defaultZone:  http://peer1:8761/eureka/,http://peer3:8763/eureka/  
application-peer3.yml
server:   port:  8763  eureka:   instance:      hostname:  peer3    client:      serviceUrl:        defaultZone:  http://peer1:8761/eureka/,http://peer2:8762/eureka/  
3. Add hostname in /etc/hosts
127.0.0.1 peer1 127.0.0.1 peer2 127.0.0.1 peer3 
4. Running Eureka server peers
Gradle
./gradlew bootRun --args='--spring.profiles.active=peer1'  ./gradlew bootRun --args='--spring.profiles.active=peer2'  ./gradlew bootRun --args='--spring.profiles.active=peer3'  
Maven
mvn spring-boot:run -Dspring-boot.run.profiles=peer1 mvn spring-boot:run -Dspring-boot.run.profiles=peer2 mvn spring-boot:run -Dspring-boot.run.profiles=peer3 
5. View Eureka server dashboards
Accessing each Eureka server dashboard, you can see that each Eureka server has two DS Replicas.
Eureka server dashboards’ URL:
Eureka Client 
1. Register a Eureka client to the Eureka Server Cluster
Add all Eureka server peers to eureka.client.serviceUrl.defaultZone
eureka:   client:      serviceUrl:        defaultZone:  http://peer1:8761/eureka/,http://peer2:8762/eureka/,http://peer3:8763/eureka/  
The complete Eureka client configuration file application.yml:
spring:   application:      name:  eureka-client  eureka:   instance:      preferIpAddress:  true      instanceId:  ${spring.application.name}:${vcap.application.instance_id:${spring.application.instance_id:${random.value}}}    client:      registerWithEureka:  true      fetchRegistry:  true      serviceUrl:        defaultZone:  http://peer1:8761/eureka/,http://peer2:8762/eureka/,http://peer3:8763/eureka/      healthcheck:        enabled:  true  server:      port:  0  management:   endpoints:      web:        exposure:          include:  health,info,beans  
More articles about Spring Cloud 
References [1] Spring Microservices in Action, Second Edition
[2] Spring Cloud Netflix Documentation 
[3] Eureka Server Cluster Setup Tutorial 
[4] Service Registration and Discovery - Spring Guides