关于Spring Cloud LoadBalancer的简单记录(Nacos环境下)
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.loadbalancer.LoadBalancerClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
@RestController
public class LoadBalancerController {
private final LoadBalancerClient loadBalancer;
private final RestTemplate restTemplate;
public LoadBalancerController(LoadBalancerClient loadBalancer, RestTemplate restTemplate) {
this.loadBalancer = loadBalancer;
this.restTemplate = restTemplate;
}
@GetMapping("/get")
public String getHello() {
// 使用LoadBalancerClient选择服务实例
ServiceInstance serviceInstance = loadBalancer.choose("nacos-discovery");
// 构建请求URI
String url = "http://" + serviceInstance.getHost() + ":" + serviceInstance.getPort() + "/hello";
// 使用RestTemplate发送请求
return restTemplate.getForObject(url, String.class);
}
}
这段代码演示了如何在Spring Cloud应用中使用LoadBalancerClient
结合RestTemplate
来进行客户端负载均衡的服务调用。它首先使用LoadBalancerClient
选择一个服务实例,然后构建出请求的URL,最后使用RestTemplate
发送HTTP GET请求。这是一个标准的模式,在微服务架构中经常用到。
评论已关闭