00.SpringCloud服务调用方式
Spring Cloud 提供了多种服务间调用的方式,以下是其中的几种:
- 使用 Spring Cloud Netflix 的 Feign 客户端
Feign 是一个声明式的 Web 服务客户端,它使得编写 Web 服务客户端变得更加简单。只需要创建一个接口并用注解的方式来配置它。
@FeignClient("service-provider")
public interface ServiceProviderClient {
@GetMapping("/data")
String getData();
}
- 使用 Spring Cloud Netflix 的 Ribbon 和 RestTemplate
Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡器。通过 RestTemplate 发起服务调用。
@Bean
@LoadBalanced
RestTemplate restTemplate() {
return new RestTemplate();
}
public String callService() {
return restTemplate.getForObject("http://service-provider/data", String.class);
}
- 使用 Spring Cloud LoadBalancer 和 WebClient
Spring Cloud LoadBalancer 是 Spring Cloud 的一个新项目,旨在提供一种更现代的方式来实现客户端负载均衡。
@Bean
public ReactiveLoadBalancer<ServiceInstance> reactiveLoadBalancer(Environment environment) {
String serviceId = environment.getProperty("spring.application.name");
return new RandomLoadBalancer(this.discoveryClient, serviceId);
}
public Mono<String> callService() {
return reactiveLoadBalancer.choose(serviceId)
.flatMap(serviceInstance -> WebClient.create(serviceInstance.getUri())
.get()
.retrieve()
.bodyToMono(String.class));
}
- 使用 Spring Cloud Gateway
Spring Cloud Gateway 是 Spring 官方提供的API网关服务,用于代理服务请求。
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes()
.route("service-provider", r -> r.path("/service-provider/**")
.uri("lb://SERVICE-PROVIDER"))
.build();
}
以上是 Spring Cloud 服务间调用的常见方式,具体使用哪种方式取决于你的具体需求和项目结构。
评论已关闭