负载均衡算法:rest接口第几次请求数 % 服务器集群总数量 = 实际调用服务器位置下表,每次服务重启后rest接口计数从1开始
整体目录结构:
1.去掉ApplicationContextConfig类中的@LodaBalanced注解
2.添加LoadBalancer接口以及实现类
package com.bysen.springcloud.lb;
import org.springframework.cloud.client.ServiceInstance;
import java.util.List;
public interface LoadBalancer {
ServiceInstance instance(List<ServiceInstance>serviceInstances);
}
package com.bysen.springcloud.lb;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.stereotype.Component;
import java.lang.annotation.Annotation;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
/**
* @ClassName MyLB
* @Author Bysen
* @Date 2020/10/12 20:44
* @Description TODO
* @Version 1.0
**/
@Component
public class MyLB implements LoadBalancer {
private AtomicInteger atomicInteger = new AtomicInteger(0);
public final int getAndIncrement(){
int curent;
int next;
do{
curent = this.atomicInteger.get();
next = curent>=Integer.MAX_VALUE?0:curent+1;
}while (!this.atomicInteger.compareAndSet(curent,next));
System.out.println("=======================next: "+next);
return next;
}
@Override
public ServiceInstance instance(List<ServiceInstance> serviceInstances) {
int index = getAndIncrement()% serviceInstances.size();
return serviceInstances.get(index);
}
}
3.OrderController添加如下方法
@GetMapping(value = "/consumer/payment/lb")
public String getPaymentLB(){
List<ServiceInstance> instances = discoveryClient.getInstances("CLOUD-PAYMENT-SERVICE");
if(instances == null || instances.size()<=0){
return null;
}
ServiceInstance serviceInstance = myLB.instance(instances);
URI uri = serviceInstance.getUri();
return restTemplate.getForObject(uri+"/payment/lb",String.class);
}