亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

詳解spring cloud中使用Ribbon實現客戶端的軟負載均衡

2024-07-13 10:16:42
字體:
來源:轉載
供稿:網友

開篇

本例是在springboot整合H2內存數據庫,實現單元測試與數據庫無關性和使用RestTemplate消費spring boot的Restful服務兩個示例的基礎上改造而來

在使用RestTemplate來消費spring boot的Restful服務示例中,我們提到,調用spring boot服務的時候,需要將服務的URL寫死或者是寫在配置文件中,但這兩種方式,無論哪一種,一旦ip地址發生了變化,都需要改動程序,并重新部署服務,使用Ribbon的時候,可以有效的避免這個問題。

前言:

軟負載均衡的實現方式有兩種,分別是服務端的負載均衡和客戶端的負載均衡

服務端負載均衡:當瀏覽器向后臺發出請求的時候,會首先向反向代理服務器發送請求,反向代理服務器會根據客戶端部署的ip:port映射表以及負載均衡策略,來決定向哪臺服務器發送請求,一般會使用到nginx反向代理技術。

客戶端負載均衡:當瀏覽器向后臺發出請求的時候,客戶端會向服務注冊器(例如:Eureka Server),拉取注冊到服務器的可用服務信息,然后根據負載均衡策略,直接命中哪臺服務器發送請求。這整個過程都是在客戶端完成的,并不需要反向代理服務器的參與。

一、啟動Eureka Server

請參考該例:spring cloud中啟動Eureka Server

二、啟動微服務,并注冊到Eureka Server上

spring cloud-將spring boot服務注冊到Eureka Server上

為了演示負載均衡的效果,再啟動一個為服務,注意需要將端口號改成不一致

三、添加Ribbon支持

1、添加Ribbon的依賴

spring,cloud,Ribbon,軟負載均衡,springcloud,負載均衡

2、添加負載均衡支持

package com.chhliu.springboot.restful; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.web.client.RestTemplateBuilder; import org.springframework.cloud.client.loadbalancer.LoadBalanced; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.context.annotation.Bean; import org.springframework.web.client.RestTemplate; @SpringBootApplication @EnableEurekaClient public class SpringbootRestTemplateApplication {      @Autowired   private RestTemplateBuilder builder;    @Bean   @LoadBalanced // 添加負載均衡支持,很簡單,只需要在RestTemplate上添加@LoadBalanced注解,那么RestTemplate即具有負載均衡的功能,如果不加@LoadBalanced注解的話,會報java.net.UnknownHostException:springboot-h2異常,此時無法通過注冊到Eureka Server上的服務名來調用服務,因為RestTemplate是無法從服務名映射到ip:port的,映射的功能是由LoadBalancerClient來實現的。   public RestTemplate restTemplate() {     return builder.build();   }    public static void main(String[] args) {     SpringApplication.run(SpringbootRestTemplateApplication.class, args);   } } 

3、修改調用微服務的URL

package com.chhliu.springboot.restful.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate;  import com.chhliu.springboot.restful.vo.User;  @RestController public class RestTemplateController {   @Autowired   private RestTemplate restTemplate;      @GetMapping("/template/{id}")   public User findById(@PathVariable Long id) {// 將原來的ip:port的形式,改成注冊到Eureka Server上的應用名即可     User u = this.restTemplate.getForObject("http://springboot-h2/user/" + id, User.class);     System.out.println(u);     return u;   } } 

四、查看Eureka Server狀態

spring,cloud,Ribbon,軟負載均衡,springcloud,負載均衡

五,在瀏覽器中,多次刷新http://localhost:7904/template/2地址

六、測試結果

7900端口服務:

Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? 

7901端口服務:

Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_, user0_.balance as balance3_0_0_, user0_.name as name4_0_0_, user0_.username as username5_0_0_ from user user0_ where user0_.id=? 

7904端口服務:

User [id=2, username=user2, name=李四, age=20, balance=100.00] 2017-01-23 09:58:05.682 INFO 7436 --- [erListUpdater-0] c.netflix.config.ChainedDynamicProperty : Flipping property: springboot-h2.ribbon.ActiveConnectionsLimit to use NEXT property: niws.loadbalancer.availabilityFilteringRule.activeConnectionsLimit = 2147483647 User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] User [id=2, username=user2, name=李四, age=20, balance=100.00] 

從上面的測試結果可以看出,總共調了7904端口服務9次,其中7904端口服務調7900端口服務4次,調7901端口5次,剛好是9次

經過上面的幾個步驟,就基本使用Ribbon實現了客戶端負載均衡的功能

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲一区精品| 欧美肥婆姓交大片| 国产精品91视频| 亚洲国产精久久久久久| 欧美性一区二区三区| 亚洲精品福利免费在线观看| 亚洲福利视频专区| 91免费综合在线| 麻豆国产va免费精品高清在线| 国产日韩精品一区二区| 欧美成人h版在线观看| 日韩精品在线观看视频| 久久久久久国产三级电影| 欧美大学生性色视频| 久久久久久久国产精品| 欧美最猛性xxxxx亚洲精品| 日韩精品亚洲元码| 欧美在线一级va免费观看| 国产精品电影在线观看| 国产成人精品电影| 欧美性xxxx极品hd满灌| 亚洲国产另类 国产精品国产免费| 欧美在线视频观看| 日韩影视在线观看| 久久精品成人欧美大片古装| 欧美黑人性生活视频| 久久久91精品国产一区不卡| 欧美日韩日本国产| 国产精品一区二区三区毛片淫片| 精品中文视频在线| 国产人妖伪娘一区91| 在线亚洲男人天堂| 日韩精品久久久久久久玫瑰园| 亚洲欧美日韩成人| 九九热精品视频在线播放| 国产精品欧美亚洲777777| 亚洲国产精品成人精品| 国产精品中文字幕久久久| 欧日韩不卡在线视频| 2021久久精品国产99国产精品| 亚洲香蕉成人av网站在线观看| 最近2019中文字幕大全第二页| 国产成人激情小视频| 日本久久久久久久久久久| 精品香蕉一区二区三区| 一本一本久久a久久精品综合小说| 色综合老司机第九色激情| 国产精品激情av电影在线观看| 91久久国产精品91久久性色| 97热在线精品视频在线观看| 国产精品aaa| 国产精品人人做人人爽| 亚洲一区二区免费在线| 欧美性感美女h网站在线观看免费| 国产91免费观看| 国产精品夜色7777狼人| 日本韩国在线不卡| xxxxx91麻豆| 中文.日本.精品| 美日韩精品免费视频| 国产国语刺激对白av不卡| 欧美与欧洲交xxxx免费观看| 日韩视频在线免费观看| 亚洲激情视频在线播放| 国产一区二区三区视频在线观看| 2019最新中文字幕| 国产免费一区二区三区在线能观看| 欧洲成人免费aa| 深夜福利国产精品| 91香蕉嫩草神马影院在线观看| 国产精品久久久久久久久久久新郎| 欧美激情精品久久久久| 日韩精品极品在线观看播放免费视频| 在线视频精品一| 亚洲国产精品人久久电影| 国产精品自拍偷拍视频| 久久久极品av| 亚洲日本中文字幕免费在线不卡| 欧美专区福利在线| 欧美精品久久一区二区| 亚洲黄在线观看| 日韩在线观看网站| 久久偷看各类女兵18女厕嘘嘘| 一区二区在线视频播放| 一本久久综合亚洲鲁鲁| 亚洲国产中文字幕在线观看| 狠狠色狠狠色综合日日小说| 国产99视频在线观看| 成人黄色av网站| 中文字幕在线视频日韩| 精品国产网站地址| 精品国产一区二区在线| 川上优av一区二区线观看| 国产成人在线一区二区| 精品中文字幕在线| 成人国产精品久久久久久亚洲| 亚洲欧美日韩天堂一区二区| 国产精品va在线播放我和闺蜜| 欧美性猛交视频| 91在线观看免费网站| 成人免费午夜电影| 国产精品99久久99久久久二8| 国产精品户外野外| 成人亚洲综合色就1024| 日韩精品在线观看一区| 欧亚精品在线观看| 精品国产一区二区三区四区在线观看| 日韩在线观看网址| 久久91亚洲精品中文字幕| 亚洲性视频网站| 亚洲伦理中文字幕| 午夜精品一区二区三区在线播放| 91欧美精品成人综合在线观看| 精品综合久久久久久97| 日韩欧美亚洲一二三区| 国内精品中文字幕| 国产精品国产三级国产专播精品人| 久久精品国产一区二区电影| 成人精品福利视频| 日本久久久久亚洲中字幕| 国产精品久久9| 亚洲精品永久免费精品| 欧美高清一级大片| 黑人精品xxx一区一二区| 在线视频国产日韩| 国模精品视频一区二区三区| 色多多国产成人永久免费网站| 日韩av在线免费播放| 在线日韩av观看| 日本91av在线播放| 国产欧美日韩精品丝袜高跟鞋| 色噜噜亚洲精品中文字幕| 亚洲va欧美va国产综合剧情| 亚洲国产又黄又爽女人高潮的| 久久99亚洲热视| 成人激情视频在线播放| 奇门遁甲1982国语版免费观看高清| 97国产精品免费视频| 欧美性xxxx极品hd满灌| 国产在线高清精品| 色播久久人人爽人人爽人人片视av| 日韩在线视频免费观看高清中文| 尤物yw午夜国产精品视频| 亚洲欧美日韩国产中文| 成人福利免费观看| 日本精品一区二区三区在线播放视频| 亚洲欧美国产日韩天堂区| 欧美成人免费全部| 久久久久久久激情视频| 亚洲精品www久久久久久广东| 色播久久人人爽人人爽人人片视av| 亚洲一区二区三区四区视频| 91在线观看免费| 国产高清视频一区三区| 久久精品视频播放| 日韩av综合中文字幕| 98视频在线噜噜噜国产| 国产精品久久久久久亚洲调教| 国产精品男人的天堂| 伊人激情综合网| 日韩av在线免费播放| 538国产精品一区二区免费视频| 国产成人午夜视频网址| 欧美午夜电影在线|