一.ribbon簡介web
ribbon是一個負載均衡客戶端,能夠很好的控制htt和tcp的一些行爲。Feign默認集成了ribbon。spring
二.準備工做瀏覽器
啓動eureka-server 工程;啓動service-hi工程,它的端口爲8762;將service-hi的配置文件的端口改成8763,並啓動,這時你會發現:service-hi在eureka-server註冊了2個實例,這就至關於一個小的集羣。訪問localhost:8761如圖所示:app
番外:IDEA啓動多個工程實例負載均衡
選擇Edit Configurationstcp
去掉右上角的Single Instance only(單實例)的對勾,此時即可以經過修改application.yml中的端口號來啓動多個工程。spring-boot
3、建一個服務消費者測試
新建一個spring-boot工程,取名爲:service-ribbon; 在它的pom.xml文件分別引入起步依賴spring-cloud-starter-eureka、spring-cloud-starter-ribbon、spring-boot-starter-weburl
在工程的配置文件指定服務的註冊中心地址爲http://localhost:8761/eureka/,程序名稱爲 service-ribbon,程序端口爲8764rest
在工程的啓動類中,經過@EnableDiscoveryClient向服務中心註冊;而且向程序的ioc注入一個bean: restTemplate;並經過@LoadBalanced註解代表這個restRemplate開啓負載均衡的功能。
寫一個測試類HelloService,經過以前注入ioc容器的restTemplate來消費service-hi服務的「/hi」接口,在這裏咱們直接用的程序名替代了具體的url地址,在ribbon中它會根據服務名來選擇具體的服務實例,根據服務實例在請求的時候會用具體的url替換掉服務名
寫一個controller,在controller中用調用HelloService 的方法
在瀏覽器上屢次訪問http://localhost:8764/hi?name=forezp,瀏覽器交替顯示:
hi forezp,i am from port:8762
hi forezp,i am from port:8763
這說明當咱們經過調用restTemplate.getForObject(「http://SERVICE-HI/hi?name=「+name,String.class)方法時,已經作了負載均衡,訪問了不一樣的端口的服務實例。