spring cloud 에서 마이크로 서비스 간 호출 및 eureka 의 자기 보호 체제 에 대한 상세 한 설명

상편 에 서 는 spring cloud 등록 센터 와 클 라 이언 트 의 등록 을 이 야 기 했 기 때문에 이 편 에 서 는 서비스 와 서비스 간 에 어떻게 호출 되 는 지 에 대해 이야기 합 니 다.
만 들 지 않 을 파트너 는 제 지난 블 로 그 를 참고 하 세 요.아이디어 빠 른 구축 spring cloud-등록 센터 및 등록
전편 의 구축 을 바탕 으로 나 는 클 라 이언 트 마이크로 서 비 스 를 스스로 구축 했다.

그래서 현재 두 개의 마이크로 서비스 가 있 는데 우리 가 실현 하 는 것 은 바로 마이크로 서비스 1 과 마이크로 서비스 2 간 의 호출 이다.
등록 센터 는 더 이상 말 할 필요 가 없 으 니,구체 적 으로 두 개의 마이크로 서 비 스 를 살 펴 보 자.

application.yml 설정 도 말 할 필요 가 없습니다.어떻게 설정 해 야 할 지 모 르 겠 습 니 다.제 블 로 그 를 참고 하 세 요.
procject-solr 의 constroller 에서:

@RestController//    Constroller             
public class SolrSearchConstroller {

  @RequestMapping("/SolrSearch")
  public String SolrSearch(){
    return "   Solr";
  }

}
여 기 는 다른 서 비 스 를 호출 하기 위해 서 입 니 다.
다른 마이크로 서비스 procject-shopping-mall 시작 클래스 에서 우 리 는 하나의 방법 을 정의 해 야 합 니 다.

@SpringBootApplication
@EnableDiscoveryClient //  eureka   
public class ShoppingMallProvider {

  @Bean
  @LoadBalanced//             
  public RestTemplate restTemplate(){

    RestTemplate restTemplate=new RestTemplate();
    return restTemplate;
  }

  public static void main(String[] args) {
    SpringApplication.run(ShoppingMallProvider.class,args);
  }
}
그리고 procject-shopping-mall 의 Controller 에서 procject-solr 의 constroller 를 호출 합 니 다.

@Controller
public class PageController {

  @Autowired
  private RestTemplate restTemplate;

  @RequestMapping("/toIndex")
  public String toIndex(Model model){

    String msg=restTemplate.getForEntity("http://project-solr/SolrSearch",String.class).getBody();//project-solr           
    model.addAttribute("msg",msg);
    return "/index";
  }
}
이 곳 의 procject-solr 는 모든 서비스 가 등록 센터 에 등 록 된 이름 을 설정 합 니 다.이름 에 따라 서비스의 ip 주 소 를 호출 하면 동적 마이크로 서비스 호출 효 과 를 실현 할 수 있 습 니 다.컴퓨터 교체 로 인해 오류 가 발생 하지 않 습 니 다.
다음은 페이지 를 만 듭 니 다.여 기 는 thymeleaf 구성 요 소 를 사용 합 니 다.
build.gradle 에 의존 도 를 추가 합 니 다:

//thymeleaf  
  compile 'org.springframework.boot:spring-boot-starter-thymeleaf'
그리고 기본 디 렉 터 리 를 새로 만 듭 니 다:

기본 디 렉 터 리 이기 때문에 templates 패 키 지 를 새로 만들어 야 합 니 다.
그리고 index.html 중:

실행:

성공!
간단하게 spring cloud eureka 등록 센터 의 자기 보호 체 제 를 말씀 드 리 겠 습 니 다.
장점:서비스 와 등록 센터 가 특정한 이유 로 끊 겼 을 때 서비스 와 서비스 간 에 연결 할 수 있 습 니 다.이때 eureka 는 바로 정리 하지 않 고 마이크로 서버 의 정 보 를 저장 합 니 다.
단점:서비스 와 등록 센터 가 어떤 이유 로 끊 겼 을 때 서비스 와 서비스 간 에 도 연결 할 수 없 으 며 이 럴 때 다른 서버 가 고장 날 수 있 습 니 다.
물론 장점 이 단점 보다 크다.
그럼 eureka 등록 센터 는 마이크로 서비스 가 살아 있다 는 것 을 어떻게 알 았 습 니까?
사실 모든 서 비 스 는 매 분 마다 등록 센터 에 심장 박동 을 하고 등록 센터 는 심장 박동 을 받 으 며 등록 센터 가 심장 박동 을 받 지 못 하면 이 서비스 가 사망 했다 고 생각 합 니 다.
공식 적 으로 자기 보호 체제 에 대한 정의:eureka 공식 자기 보호 메커니즘
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.

좋은 웹페이지 즐겨찾기