>Java >java지도 시간 >Java 마이크로서비스 아키텍처의 서비스 검색

Java 마이크로서비스 아키텍처의 서비스 검색

WBOY
WBOY원래의
2024-06-02 12:09:571051검색

Java 마이크로서비스의 서비스 검색을 통해 애플리케이션은 다른 서비스를 동적으로 검색하고 연결할 수 있습니다. Eureka는 서비스 등록, 검색 및 로드 밸런싱을 제공하는 클라이언트/서버 시스템입니다. Spring Cloud Eureka는 자동 등록, 로드 밸런싱 및 Spring 통합을 제공하는 Eureka의 Spring Cloud 구현입니다. zkclient는 서비스 검색에도 사용할 수 있으므로 애플리케이션이 Zookeeper를 통해 서비스 주소를 검색할 수 있습니다.

Java 마이크로서비스 아키텍처의 서비스 검색

Java 마이크로서비스 아키텍처의 서비스 검색

소개

마이크로서비스 아키텍처에서 서비스 검색은 애플리케이션이 동적으로 다른 서비스를 검색하고 연결할 수 있도록 해주기 때문에 매우 중요합니다. Java에는 여러 가지 서비스 검색 기술이 있으며 이 기사에서는 그 중 일부를 살펴보고 실제 예제를 제공합니다.

Eureka

Eureka는 Netflix에서 개발한 오픈 소스 서비스 검색 프레임워크입니다. 유레카 서버가 서비스 레지스트리를 저장하고, 유레카 클라이언트가 주기적으로 서버에 서비스를 등록하는 클라이언트/서버 시스템입니다. Eureka는 다음 기능을 제공합니다.

  • 서비스 등록 및 등록 취소
  • 서비스 검색
  • 로드 밸런싱

Spring Cloud:

Spring Cloud Eureka는 Eureka 클라이언트를 제공하는 Spring Cloud 생태계의 Eureka 구현입니다. Spring 애플리케이션과 완벽하게 통합됩니다. 다음 기능을 제공합니다:

  • 자동 서비스 등록 및 등록 취소
  • 구성 가능한 로드 밸런싱 전략
  • Spring Boot 및 Spring Cloud 구성 속성과 통합

실용 사례

Spring Cloud Eureka를 사용하여 서비스 검색:

  1. Maven pom.xml 파일에 Eureka 종속성 추가:
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    <version>3.1.0</version>
</dependency>
  1. Eureka 서비스 클래스 생성:
@SpringBootApplication
@EnableEurekaClient
public class EurekaClientApplication {

    public static void main(String[] args) {
        SpringApplication.run(EurekaClientApplication.class, args);
    }

}
  1. @EnableEurekaClient 주석을 통해 Eureka 클라이언트를 활성화하고 @SpringBootApplication을 사용합니다. code>는 서비스 클래스를 표시합니다. @EnableEurekaClient 注解启用 Eureka 客户端,并使用 @SpringBootApplication 标记服务类。
  2. 在 Eureka 服务器上启动应用程序,然后通过调用以下端点检查服务是否已注册:

http://localhost:8761/eureka/apps/[service-name]

使用 zkclient 发现服务:

  1. 在 Maven pom.xml 文件中添加 zkclient 依赖:
<dependency>
    <groupId>com.101tec</groupId>
    <artifactId>zkclient</artifactId>
    <version>0.11</version>
</dependency>
  1. 创建 Zookeeper 服务发现类:
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();
    }

}
  1. 使用 discoverServices() 方法发现服务并获取其地址。
  2. 在关闭服务时,调用 close()
  3. Eureka 서버에서 애플리케이션을 시작하고 다음 엔드포인트를 호출하여 서비스가 등록되었는지 확인하세요.
🎜🎜http://localhost:8761/eureka/apps/[service-name]🎜 🎜 🎜zkclient를 사용하여 서비스 검색: 🎜🎜🎜🎜Maven pom.service에 zkclient 종속성을 추가하고 해당 주소를 가져옵니다. 🎜🎜서비스를 닫을 때 close() 메서드를 호출하여 Zookeeper 클라이언트 리소스를 해제하세요. 🎜🎜

위 내용은 Java 마이크로서비스 아키텍처의 서비스 검색의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.