Java マイクロサービスのサービス検出により、アプリケーションが他のサービスを動的に検出して接続できるようになります。 Eureka は、サービスの登録、検出、負荷分散を提供するクライアント/サーバー システムです。 Spring Cloud Eureka は Eureka の Spring Cloud 実装であり、自動登録、負荷分散、Spring 統合を提供します。 zkclient はサービス検出にも使用でき、アプリケーションが Zookeeper を通じてサービス アドレスを検出できるようになります。
Java マイクロサービス アーキテクチャにおけるサービス ディスカバリ
はじめに
マイクロサービス アーキテクチャでは、アプリケーションが他のサービスを動的に検出して接続できるようにするため、サービス ディスカバリは非常に重要です。 Java にはいくつかのサービス検出テクノロジがあり、この記事ではそれらのいくつかを検討し、実践的な例を示します。
Eureka
Eureka は、Netflix によって開発されたオープンソースのサービス検出フレームワークです。これは、Eureka サーバーがサービス レジストリを保存し、Eureka クライアントが定期的にサービスをサーバーに登録するクライアント/サーバー システムです。 Eureka は次の機能を提供します:
Spring Cloud:
Spring Cloud Eureka は Spring Cloud エコシステムにおける Eureka の実装であり、Eureka クライアントを提供します。 Spring アプリケーションとシームレスに統合されます。以下の機能を提供します:
実用的なケース
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
アノテーションを介して Eureka クライアントを有効にし、@SpringBootApplication を使用します。 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]
🎜 🎜 🎜 zkclient を使用してサービスを検出します。 🎜🎜🎜🎜 Maven pom サービスに zkclient 依存関係を追加し、そのアドレスを取得します。 🎜🎜サービスを閉じるときは、close()
メソッドを呼び出して Zookeeper クライアント リソースを解放します。 🎜🎜以上がJava マイクロサービス アーキテクチャでのサービス検出の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。