詳解springcloud中使用Ribbon實現(xiàn)客戶端的軟負載均衡-創(chuàng)新互聯(lián)

開篇

成都創(chuàng)新互聯(lián)公司-云計算及IDC服務提供商,涵蓋公有云、IDC機房租用、四川雅安電信機房、等保安全、私有云建設等企業(yè)級互聯(lián)網(wǎng)基礎服務,咨詢電話:18980820575

本例是在springboot整合H2內(nèi)存數(shù)據(jù)庫,實現(xiàn)單元測試與數(shù)據(jù)庫無關(guān)性和使用RestTemplate消費spring boot的Restful服務兩個示例的基礎上改造而來


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

前言:


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


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


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


一、啟動Eureka Server


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


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


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


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


三、添加Ribbon支持


1、添加Ribbon的依賴

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-h3異常,此時無法通過注冊到Eureka Server上的服務名來調(diào)用服務,因為RestTemplate是無法從服務名映射到ip:port的,映射的功能是由LoadBalancerClient來實現(xiàn)的。 
  public RestTemplate restTemplate() { 
    return builder.build(); 
  } 
 
  public static void main(String[] args) { 
    SpringApplication.run(SpringbootRestTemplateApplication.class, args); 
  } 
} 

分享題目:詳解springcloud中使用Ribbon實現(xiàn)客戶端的軟負載均衡-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://muchs.cn/article18/dpipdp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、標簽優(yōu)化、網(wǎng)站改版、網(wǎng)站導航網(wǎng)站排名、定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務器托管