您好,登錄后才能下訂單哦!
這篇文章主要介紹了Spring Cloud Alibaba負載均衡的實現方式是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇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是什么? Netflix開源的客戶端側負載均衡器
更加直觀說就是ribbon就是簡化我們這段代碼的小組件,不過他比我們的代碼要強大一些,他給他們提供了豐富的負載均衡算法。
引入ribbon :三步驟: 加依賴,啟動注解,寫配置
不需要加,nacosdiscovery,已經給添加了依賴,
寫注解,需要寫到RestTemplate上面。
第三步:寫配置
沒有配置。
改造我們的請求:
url:改為 下面 當請求發送的發送的時候ribbon會將nx-us進行轉化為我們nacos里面中的地址。并且進行負載均衡算法,進行請求,
關于“Spring Cloud Alibaba負載均衡的實現方式是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Spring Cloud Alibaba負載均衡的實現方式是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。