负载均衡,轮询算法
面向接口编程:

有接口必有实现:

测试:

附上代码
接口:
package com.wwjj.springcloud.lb;
import org.springframework.cloud.client.ServiceInstance;
import java.util.List;
public interface LoadBalancer
{
ServiceInstance instance(List<ServiceInstance> instances );//得到活着的服务
}
实现类
package com.wwjj.springcloud.lb;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.stereotype.Component;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
@Component
public class MyLb implements LoadBalancer
{
private AtomicInteger atomicInteger = new AtomicInteger(0);
public final int getAndIncrement(){
int current;
int next;
do {
current = this.atomicInteger.get();
next = current >= 2147483647 ? 0 : current+1;
}while (!this.atomicInteger.compareAndSet(current,next));//自旋
System.out.println("**********第几次访问:next:"+next);
return next;
}
@Override
public ServiceInstance instance(List<ServiceInstance> serviceInstances) {
int index = getAndIncrement() % serviceInstances.size();
return serviceInstances.get(index);//返回某个服务
}
}
最后测试
@Resource
private RestTemplate restTemplate;
@Resource
private LoadBalancer loadBalancer;
@Resource
private DiscoveryClient discoveryClient;
@GetMapping("/consumer/payment/lb")
public String getPaymentLb(){
//根据服务名称获得服务
List<ServiceInstance> instances = discoveryClient.getInstances("CLOUD-PAYMENT-SERVICE");
//判断是否获得服务
if (instances==null || instances.size()<=0){
return null;
}else {
ServiceInstance serviceInstance = loadBalancer.instance(instances);
URI uri = serviceInstance.getUri();
return restTemplate.getForObject(uri+"/payment/lb",String.class);
}
}

本文介绍了负载均衡中的轮询算法,通过接口定义和实现,阐述了如何进行请求分发。测试结果显示了算法的运作过程。

3067

被折叠的 条评论
为什么被折叠?



