Spring Cloud Alibaba負載均衡實現方式

一、負載均衡的兩種方式

服務器端負載均衡

傳統的方式前端發送請求會到我們的的nginx上去,nginx作為反向代理,然後路由給後端的服務器,由於負載均衡算法是nginx提供的,而nginx是部署到服務器端的,所以這種方式又被稱為服務器端負載均衡。

客戶端側負載均衡

現在有三個實例,內容中心可以通過discoveryClient 獲取到用戶中心的實例信息,如果我們再訂單中心寫一個負載均衡的規則計算請求那個實例,交給restTemplate進行請求,這樣也可以實現負載均衡,這個算法裡面,負載均衡是有訂單中心提供的,而訂單中心相對於用戶中心是一個客戶端,所以這種方式又稱為客戶端負負載均衡。

二、手寫一個客戶端側負載均衡器

◆隨機選擇實例

@Autowired
private DiscoveryClient discoveryClient;
@GetMapping("/order/create")
public String createOrder(Integer productId,Integer userId){
    List<ServiceInstance> instances = discoveryClient.getInstances("msb-stock");
    List<String> targetUrls = instances.stream()
        // 數據變換
        .map(instance -> instance.getUri().toString() + "/stock/reduce")
        .collect(Collectors.toList());
    int i = ThreadLocalRandom.current().nextInt(targetUrls.size());
    String targetUrl = targetUrls.get(i);
    log.info("請求求目標地址:{}",targetUrl);
    String result = restTemplate.getForObject(targetUrl +"/"+ productId, String.class);
    log.info("進行減庫存:{}",result);
    return "下單成功";
}

三、使用Ribbon實現負載均衡

Ribbon是什麼? Netflix開源的客戶端側負載均衡器

更加直觀說就是ribbon就是簡化我們這段代碼的小組件,不過他比我們的代碼要強大一些,他給他們提供瞭豐富的負載均衡算法。

引入ribbon :三步驟: 加依賴,啟動註解,寫配置

不需要加,nacosdiscovery,已經給添加瞭依賴,

寫註解,需要寫到RestTemplate上面。

第三步:寫配置

沒有配置。

改造我們的請求:

url:改為 下面 當請求發送的發送的時候ribbon會將nx-us進行轉化為我們nacos裡面中的地址。並且進行負載均衡算法,進行請求,

以上就是Spring Cloud Alibaba負載均衡實現方式的詳細內容,更多關於Spring Cloud Alibaba負載均衡的資料請關註WalkonNet其它相關文章!

推薦閱讀: