package com.eureakorder.api.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.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
import java.util.List;
//纯手写ribbon本地负载均衡,如果使用这个本地负载均衡、需要将启动类的负载均衡的注解 @LoadBalanced注释掉
@RestController
public class ExtRibbonController {
//可以获取注册中心服务上的注册列表
@Autowired
private DiscoveryClient discoveryClient;
@Autowired
private RestTemplate restTemplate;
//定义接口请求总数(此处定义是不安全的,要用原子性)
private int reqCount=1;
@RequestMapping("/getRibbon")
public String ribbonMember(){
String instanceUrl=getInstance()+"/getMember";
System.out.println("instanceUrl:"+instanceUrl);
//2、使用rest方式发送请求
String result=restTemplate.getForObject(instanceUrl,String.class);
return result;
}
public String getInstance(){
//1、获取对应服务器的远程调用地址(接口地址可能是个集群,所以返回结果集是个集合)
List<ServiceInstance> instances=discoveryClient.getInstances("eureka-member");
if(instances==null||instances.size()<1){
return "";
}
//获取服务器集群个数
int instanceSize=instances.size();
int serviceIndex=reqCount % instanceSize;
reqCount++;
return instances.get(serviceIndex).getUri().toString();
}
}