溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Ribbon如何負(fù)載均衡地消費(fèi)microservice-provider-user

發(fā)布時(shí)間:2022-01-10 11:56:00 來(lái)源:億速云 閱讀:238 作者:柒染 欄目:開發(fā)技術(shù)

這篇文章給大家介紹Ribbon如何負(fù)載均衡地消費(fèi)microservice-provider-user,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

  要想消費(fèi)microservice-provider-user的服務(wù)是很簡(jiǎn)單的,我們只需要使用RestTemplate即可,或者例如HttpClient之類的http工具也是可以的。但是在集群環(huán)境下,我們必然是每個(gè)服務(wù)部署多個(gè)實(shí)例,那么服務(wù)消費(fèi)者消費(fèi)服務(wù)提供者時(shí)的負(fù)載均衡又要如何做呢?

  1.準(zhǔn)備工作

  啟動(dòng)注冊(cè)中心:microservice-discovery-eureka

  啟動(dòng)服務(wù)提供方:microservice-provider-user

  修改microservice-provider-user的端口為8001,另外啟動(dòng)一個(gè)實(shí)例

  此時(shí),訪問http://discovery:8761

  可以在Eureka中看到microservice-provider-user有兩個(gè)實(shí)例在運(yùn)行。

  下面我們創(chuàng)建一個(gè)新的微服務(wù)(microservice-consumer-movie-*),負(fù)載均衡地消費(fèi)microservice-provider-user的服務(wù)。

  2.Ribbon介紹

  Ribbon是Netflix發(fā)布的開源項(xiàng)目,主要功能是提供客戶端的軟件負(fù)載均衡算法,將Netflix的中間層服務(wù)連接在一起。Ribbon客戶端組件提供一系列完善的配置項(xiàng)如連接超時(shí),重試等。簡(jiǎn)單的說(shuō),就是在配置文件中列出Load Balancer后面所有的機(jī)器,Ribbon會(huì)自動(dòng)的幫助你基于某種規(guī)則(如簡(jiǎn)單輪詢,隨即連接等)去連接這些機(jī)器。我們也很容易使用Ribbon實(shí)現(xiàn)自定義的負(fù)載均衡算法。簡(jiǎn)單地說(shuō),Ribbon是一個(gè)客戶端負(fù)載均衡器。Ribbon工作時(shí)分為兩步:第一步先選擇 Eureka Server, 它優(yōu)先選擇在同一個(gè)Zone且負(fù)載較少的Server;第二步再根據(jù)用戶指定的策略,在從Server取到的服務(wù)注冊(cè)列表中選擇一個(gè)地址。其中Ribbon提供了三種策略:輪詢、斷路器和根據(jù)響應(yīng)時(shí)間加權(quán)。

  3.開發(fā)

  創(chuàng)建一個(gè)Maven項(xiàng)目,并在pom.xml中加入如下內(nèi)容:

  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://m

  aven.apache.org/xsd/maven-4.0.0.xsd">

  4.0.0

  microservice-consumer-movie-ribbon

  jar

  com.itmuch.cloud

  spring-cloud-microservice-study

  0.0.1-SNAPSHOT

  org.springframework.cloud

  spring-cloud-starter-eureka

  org.springframework.cloud

  spring-cloud-starter-ribbon

  org.springframework.boot

  spring-boot-starter-actuator

  啟動(dòng)類:MovieRibbonApplication.java。使用@LoadBalanced注解,為RestTemplate開啟負(fù)載均衡的能力。

  @SpringBootApplication

  @EnableDiscoveryClient

  public class MovieRibbonApplication {

  /**

  * 實(shí)例化RestTemplate,通過(guò)@LoadBalanced注解開啟均衡負(fù)載能力.

  * @return restTemplate

  */

  @Bean

  @LoadBalanced

  public RestTemplate restTemplate() {

  return new RestTemplate();

  }

  public static void main(String[] args) {

  SpringApplication.run(MovieRibbonApplication.class, args);

  }

  }

  實(shí)體類:User.java

  public class User {

  private Long id;

  private String username;

  private Integer age;

  ...

  // getters and setters

  }

  Ribbon的測(cè)試類:RibbonService.java

  @Service

  public class RibbonService {

  @Autowired

  private RestTemplate restTemplate;

  public User findById(Long id) {

  // http://服務(wù)提供者的serviceId/url

  return this.restTemplate.getForObject("http://microservice-p

  rovider-user/" + id, User.class);

  }無(wú)錫×××醫(yī)院 https://yyk.familydoctor.com.cn/20612/

  }

  controller:RibbonController.java

  @RestController

  public class RibbonController {

  @Autowired

  private RibbonService ribbonService;

  @GetMapping("/ribbon/{id}")

  public User findById(@PathVariable Long id) {

  return this.ribbonService.findById(id);

  }

  }

  application.yml

  server:

  port: 8010

  spring:

  application:

  name: microservice-consumer-movie-ribbon

  eureka:

  client:

  serviceUrl:

  instance:

  preferIpAddress: true

  啟動(dòng)后,訪問多次http://localhost:8010/ribbon/1,返回結(jié)果:

  {

  "id": 1,

  "username": "Tom",

  "age": 12

  }

  然后打開兩個(gè)microservice-provider-user實(shí)例的控制臺(tái),發(fā)現(xiàn)兩個(gè)實(shí)例都輸出了類似如下的日志內(nèi)容:

  Hibernate: select user0_.id as id1_0_0_, user0_.age as age2_0_0_,

  user0_.username as username3_0_0_ from user user0_ where user0_.id=?

  2016-09-13 21:38:56.719 TRACE 17404 --- [nio-8000-exec-1] o.h.type.descriptor.sql.BasicBinder :

  binding parameter [1] as [BIGINT] - [1]

  2016-09-13 21:38:56.720 TRACE 17404 --- [nio-8000-exec-1] o.h.type.descriptor.sql.BasicExtractor :

  extracted value ([age2_0_0_] : [INTEGER]) - [12]

  2016-09-13 21:38:56.720 TRACE 17404 --- [nio-8000-exec-1] o.h.type.descriptor.sql.BasicExtractor :

  extracted value ([username3_0_0_] : [VARCHAR]) - [Tom]

  2016-09-13 21:39:10.588 INFO 17404 --- [trap-executor-0] c.n.d.s.r.aws.ConfigClusterResolver :

  Resolving eureka endpoints

  via configuration

  至此,我們已經(jīng)通過(guò)Ribbon在客戶端側(cè)實(shí)現(xiàn)了均衡負(fù)載。

關(guān)于Ribbon如何負(fù)載均衡地消費(fèi)microservice-provider-user就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI