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其它相關文章!
推薦閱讀:
- Spring cloud alibaba之Ribbon負載均衡實現方案
- Java Spring Cloud 負載均衡詳解
- 淺談SpringCloud之Ribbon詳解
- 聊聊SpringCloud中的Ribbon進行服務調用的問題
- Java之Springcloud Feign組件詳解