Die Diensterkennung in Java-Microservices ermöglicht es Anwendungen, andere Dienste dynamisch zu erkennen und eine Verbindung zu ihnen herzustellen. Eureka ist ein Client/Server-System, das Dienstregistrierung, Erkennung und Lastausgleich ermöglicht. Spring Cloud Eureka ist die Spring Cloud-Implementierung von Eureka und bietet automatische Registrierung, Lastausgleich und Spring-Integration. zkclient kann auch zur Diensterkennung verwendet werden, sodass Anwendungen Dienstadressen über Zookeeper ermitteln können.
Diensterkennung in der Java-Microservices-Architektur
Einführung
In der Microservices-Architektur ist die Diensterkennung von entscheidender Bedeutung, da sie es Anwendungen ermöglicht, andere Dienste dynamisch zu erkennen und sich mit ihnen zu verbinden. In Java gibt es mehrere Service-Discovery-Technologien. In diesem Artikel werden einige davon untersucht und praktische Beispiele bereitgestellt.
Eureka
Eureka ist ein von Netflix entwickeltes Open-Source-Service-Discovery-Framework. Es handelt sich um ein Client/Server-System, bei dem der Eureka-Server eine Dienstregistrierung speichert und der Eureka-Client regelmäßig Dienste beim Server registriert. Eureka bietet die folgenden Funktionen:
Spring Cloud:
Spring Cloud Eureka ist eine Implementierung von Eureka im Spring Cloud-Ökosystem, die einen Eureka-Client bereitstellt das sich nahtlos in Spring-Anwendungen integrieren lässt. Es bietet die folgenden Funktionen:
Praktischer Fall
Erkennen von Diensten mit Spring Cloud Eureka:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> <version>3.1.0</version> </dependency>
@SpringBootApplication @EnableEurekaClient public class EurekaClientApplication { public static void main(String[] args) { SpringApplication.run(EurekaClientApplication.class, args); } }
@EnableEurekaClient
aktivieren und @SpringBootApplication</ verwenden code> markiert die Serviceklasse. <code>@EnableEurekaClient
注解启用 Eureka 客户端,并使用 @SpringBootApplication
标记服务类。http://localhost:8761/eureka/apps/[service-name]
使用 zkclient 发现服务:
<dependency> <groupId>com.101tec</groupId> <artifactId>zkclient</artifactId> <version>0.11</version> </dependency>
import org.I0Itec.zkclient.ZkClient; import org.I0Itec.zkclient.serialize.SerializableSerializer; import java.util.*; public class ZkServiceDiscovery { private static final String ZOOKEEPER_ADDRESS = "localhost:2181"; private static final int SESSION_TIMEOUT = 3000; private static final int CONNECTION_TIMEOUT = 3000; private ZkClient zkClient; public ZkServiceDiscovery() { zkClient = new ZkClient(ZOOKEEPER_ADDRESS, SESSION_TIMEOUT, CONNECTION_TIMEOUT, new SerializableSerializer()); } public List<String> discoverServices(String serviceName) { List<String> servicePaths = zkClient.getChildren("/services/" + serviceName + "/instances"); List<String> services = new ArrayList<>(); for (String servicePath : servicePaths) { services.add(zkClient.readData("/services/" + serviceName + "/instances/" + servicePath)); } return services; } public void close() { zkClient.close(); } }
discoverServices()
方法发现服务并获取其地址。close()
http://localhost:8761/eureka/apps/[service-name]
🎜 🎜 🎜Verwenden Sie zkclient, um Dienste zu entdecken: 🎜🎜🎜🎜Fügen Sie eine zkclient-Abhängigkeit im Maven-POM-Dienst hinzu und rufen Sie deren Adresse ab. 🎜🎜Wenn Sie den Dienst schließen, rufen Sie die Methode close()
auf, um Zookeeper-Clientressourcen freizugeben. 🎜🎜Das obige ist der detaillierte Inhalt vonServiceerkennung in der Java-Microservices-Architektur. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!