亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Spring?Cloud?Alibaba負載均衡的實現方式是什么

發布時間:2023-03-13 17:30:12 來源:億速云 閱讀:118 作者:iii 欄目:開發技術

這篇文章主要介紹了Spring Cloud Alibaba負載均衡的實現方式是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Spring Cloud Alibaba負載均衡的實現方式是什么文章都會有所收獲,下面我們一起來看看吧。

    一、負載均衡的兩種方式

    服務器端負載均衡

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

    Spring?Cloud?Alibaba負載均衡的實現方式是什么

    客戶端側負載均衡

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

    Spring?Cloud?Alibaba負載均衡的實現方式是什么

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

    ◆隨機選擇實例

    @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就是簡化我們這段代碼的小組件,不過他比我們的代碼要強大一些,他給他們提供了豐富的負載均衡算法。

    Spring?Cloud?Alibaba負載均衡的實現方式是什么

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

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

    Spring?Cloud?Alibaba負載均衡的實現方式是什么

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

    Spring?Cloud?Alibaba負載均衡的實現方式是什么

    第三步:寫配置

    沒有配置。

    改造我們的請求:

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

    Spring?Cloud?Alibaba負載均衡的實現方式是什么

    關于“Spring Cloud Alibaba負載均衡的實現方式是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Spring Cloud Alibaba負載均衡的實現方式是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    梨树县| 乌恰县| 宁乡县| 海门市| 乌兰浩特市| 福海县| 岳池县| 井研县| 山东省| 灵石县| 永泰县| 鄂尔多斯市| 双鸭山市| 深圳市| 湛江市| 榆树市| 雅安市| 宜州市| 景谷| 栖霞市| 平昌县| 吕梁市| 壤塘县| 金华市| 玛纳斯县| 宝清县| 清丰县| 华坪县| 托克托县| 天长市| 防城港市| 抚远县| 香河县| 徐州市| 嘉荫县| 镇沅| 屯门区| 岑巩县| 民县| 宜川县| 和田市|