Ribbon負(fù)載均衡算法原理與使用介紹
負(fù)載均衡算法:rest接口第幾次請求數(shù) % 服務(wù)器集群總數(shù)量 = 實(shí)際調(diào)用服務(wù)器位置下標(biāo) ,每次服務(wù)重啟動后rest接口計(jì)數(shù)從1開始。
List<ServiceInstance> instances = discoveryClient.getInstances("CLOUD-PAYMENT-SERVICE");
如:
List [0] instances = 127.0.0.1:8002
List [1] instances = 127.0.0.1:8001
8001+ 8002 組合成為集群,它們共計(jì)2臺機(jī)器,集群總數(shù)為2, 按照輪詢算法原理:
當(dāng)總請求數(shù)為1時(shí): 1 % 2 =1 對應(yīng)下標(biāo)位置為1 ,則獲得服務(wù)地址為127.0.0.1:8001
當(dāng)總請求數(shù)位2時(shí): 2 % 2 =0 對應(yīng)下標(biāo)位置為0 ,則獲得服務(wù)地址為127.0.0.1:8002
當(dāng)總請求數(shù)位3時(shí): 3 % 2 =1 對應(yīng)下標(biāo)位置為1 ,則獲得服務(wù)地址為127.0.0.1:8001
當(dāng)總請求數(shù)位4時(shí): 4 % 2 =0 對應(yīng)下標(biāo)位置為0 ,則獲得服務(wù)地址為127.0.0.1:8002
如此類推......
寫一個(gè)本地負(fù)載均衡器
設(shè)現(xiàn)在有倆個(gè)服務(wù)端口8001 8002幼由80端口調(diào)動
其中8001 8002 的controller中
@GetMapping(value = "/payment/lb")
public String getPaymentLB()
{
return serverPort;
}80 的一個(gè)接口為:
public interface LoadBalancer
{
ServiceInstance instances(List<ServiceInstance> serviceInstances);
}
實(shí)現(xiàn)類
@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 instances(List<ServiceInstance> serviceInstances)
{
int index = getAndIncrement() % serviceInstances.size();
return serviceInstances.get(index);
}
}調(diào)用 方法
@Resource
private RestTemplate restTemplate;
//可以獲取注冊中心上的服務(wù)列表
@Resource
private DiscoveryClient discoveryClient;
@Resource
private LoadBalancer loadBalancer;
@GetMapping("/consumer/payment/lb")
public String getPaymentLB()
{
List<ServiceInstance> instances = discoveryClient.getInstances("CLOUD-PAYMENT-SERVICE");
if(instances == null || instances.size()<=0) {
return null;
}
ServiceInstance serviceInstance = loadBalancer.instances(instances);
URI uri = serviceInstance.getUri();
return restTemplate.getForObject(uri+"/payment/lb",String.class);
}ApplicationContextBean去掉注解@LoadBalanced

到此這篇關(guān)于Ribbon負(fù)載均衡算法原理與使用介紹的文章就介紹到這了,更多相關(guān)Ribbon負(fù)載均衡內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis collection關(guān)聯(lián)查詢多個(gè)參數(shù)方式
在使用MyBatis進(jìn)行關(guān)聯(lián)查詢時(shí),往往需要根據(jù)多個(gè)參數(shù)進(jìn)行查詢,例如,使用evtId和businessType作為查詢條件,同時(shí)在resultMap中配置id和businessType1作為結(jié)果映射,這種情況下,可以通過<sql>標(biāo)簽定義參數(shù)模板,或者使用@Param注解指定參數(shù)名稱2024-10-10
Spring中的監(jiān)聽器SpringApplicationRunListener詳解
這篇文章主要介紹了Spring中的監(jiān)聽器SpringApplicationRunListener詳解,命名我們就可以知道它是一個(gè)監(jiān)聽者,分析springboot啟動流程我們會發(fā)現(xiàn),它其實(shí)是用來在整個(gè)啟動流程中接收不同執(zhí)行點(diǎn)事件通知的監(jiān)聽者,需要的朋友可以參考下2023-11-11
Java使用BigDecimal進(jìn)行運(yùn)算封裝的實(shí)際案例
今天小編就為大家分享一篇關(guān)于Java使用BigDecimal進(jìn)行運(yùn)算封裝的實(shí)際案例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12
Springboot實(shí)現(xiàn)視頻上傳及壓縮功能
這篇文章主要介紹了Springboot實(shí)現(xiàn)視頻上傳及壓縮功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
Spring Cloud 負(fù)載均衡器 Ribbon原理及實(shí)現(xiàn)
這篇文章主要介紹了Spring Cloud 負(fù)載均衡器 Ribbon原理及實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03
java實(shí)現(xiàn)隨機(jī)輸出300題四則運(yùn)算
本文主要介紹了java實(shí)現(xiàn)隨機(jī)輸出300題四則運(yùn)算實(shí)例,具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03

