Spring Cloud Zookeeper 기반 서비스 등록 및 발견

서비스 등록
1.Spring Cloud Zookeeper 의존 도 추가:

<dependencies>
	<dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
		<exclusions>
			<exclusion>
				<groupId>org.apache.zookeeper</groupId>
				<artifactId>zookeeper</artifactId>
			</exclusion>
		</exclusions>
	</dependency>
	<dependency>
		<groupId>org.apache.zookeeper</groupId>
		<artifactId>zookeeper</artifactId>
		<version>3.6.2</version>
		<exclusions>
			<exclusion>
				<groupId>org.slf4j</groupId>
				<artifactId>slf4j-log4j12</artifactId>
			</exclusion>
		</exclusions>
	</dependency>
	<dependency>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-web</artifactId>
	</dependency>
</dependencies>
2.서비스 프로필 에 zookeeper 설정 추가:

spring:
 cloud:
  zookeeper:
   connect-string: localhost:2181 #zookeeper  
3.zookeeper 서버 와 서 비 스 를 시작 합 니 다.(저 는 provider 와 consumer 두 서 비 스 를 시 작 했 습 니 다.)그리고 zookeeper 클 라 이언 트 에서 zookeeper 에 등 록 된 서 비 스 를 볼 수 있 습 니 다.

서비스 발견
1.controller 만 들 기
소비자 컨트롤 러:

package com.buhe.zk.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

import java.util.List;

@RestController
public class ZkConsumerController {
  private static final String SERVICE_NAME = "provider";
  private static final String SERVICE_PATH = "/zk/provider";

  @Autowired
  private RestTemplate restTemplate;

  @Autowired
  private DiscoveryClient discoveryClient;

  /**
   *        
   * @return
   */
  @GetMapping("/zk/consumer")
  public String zkConsumer(){
    return "   " + restTemplate.getForObject("http://" + SERVICE_NAME + SERVICE_PATH, String.class);
  }

  /**
   *        URL
   * @return
   */
  @GetMapping("/zk/url")
  public String serviceUrl() {
    List<ServiceInstance> list = discoveryClient.getInstances(SERVICE_NAME);
    if (list != null && list.size() > 0 ) {
      return list.get(0).getUri().toString() + SERVICE_PATH;
    }
    return null;
  }

}
RestTemplate 를 사용 하려 면 설정 추가 하 는 것 을 잊 지 마 세 요:

@Bean
@LoadBalanced
public RestTemplate restTemplate(){
	return new RestTemplate();
}
공급 자 컨트롤 러:

package com.buhe.zk.controller;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class ZkProviderController {

  @GetMapping("/zk/provider")
  public String zkProvider(){
    return "10   ";
  }
}
2.서비스 호출

이상 은 Spring Cloud Zookeeper 를 바탕 으로 서비스 등록 과 발견 을 실현 하 는 상세 한 내용 입 니 다.Spring Cloud Zookeeper 서비스 등록 과 발견 에 관 한 자 료 는 저희 의 다른 관련 글 을 주목 하 시기 바 랍 니 다!

좋은 웹페이지 즐겨찾기