真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡

這篇文章將為大家詳細(xì)講解有關(guān)SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)建站專注于突泉企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城網(wǎng)站開發(fā)。突泉網(wǎng)站建設(shè)公司,為突泉等地區(qū)提供建站服務(wù)。全流程按需開發(fā),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)

結(jié)構(gòu)下圖所示。

SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡

一、服務(wù)器

1、創(chuàng)建項(xiàng)目

開發(fā)工具:IntelliJ IDEA 2019.2.3

IDEA中創(chuàng)建一個新的SpringBoot項(xiàng)目,名稱為“cloud-server”,SpringBoot版本選擇2.1.10,在選擇Dependencies(依賴)的界面勾選Spring Cloud Discovert ->

Eureka Server,創(chuàng)建完成后的pom.xml配置文件自動添加SpringCloud最新穩(wěn)定版本依賴,當(dāng)前為Greenwich.SR3。

pom.xml完整內(nèi)容如下:



  4.0.0
  
    org.springframework.boot
    spring-boot-starter-parent
    2.1.10.RELEASE
     
  
  com.example
  cloud-server
  0.0.1-SNAPSHOT
  cloud-server
  Demo project for Spring Boot

  
    1.8
    Greenwich.SR3
  

  
    
      org.springframework.cloud
      spring-cloud-starter-netflix-eureka-server
    

    
      org.springframework.boot
      spring-boot-starter-test
      test
    
  

  
    
      
        org.springframework.cloud
        spring-cloud-dependencies
        ${spring-cloud.version}
        pom
        import
      
    
  

  
    
      
        org.springframework.boot
        spring-boot-maven-plugin
      
    
  

2、修改配置application.yml

server:
 port: 8761
eureka:
 client:
  register-with-eureka: false
  fetch-registry: false

3、修改啟動類代碼CloudServerApplication.java

增加注解@EnableEurekaServer

package com.example.cloudserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class CloudServerApplication {

  public static void main(String[] args) {
    SpringApplication.run(CloudServerApplication.class, args);
  }

}

二、服務(wù)提供者

1、創(chuàng)建項(xiàng)目

IDEA中創(chuàng)建一個新的SpringBoot項(xiàng)目,除了名稱為“cloud-provider”,其它步驟和上面創(chuàng)建服務(wù)器端一樣。

2、修改配置application.yml

spring:
 application:
  name: cloud-provider
eureka:
 instance:
  hostname: localhost
 client:
  serviceUrl:
   defaultZone: http://localhost:8761/eureka/

3、修改啟動類代碼CloudProviderApplication.java

增加注解@EnableEurekaClient;

讓類在啟動時讀取控制臺輸入,決定使用哪個端口啟動服務(wù)器;

增加一個測試用的控制器方法。

package com.example.cloudprovider;

//import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import java.util.Scanner;

@SpringBootApplication
@EnableEurekaClient
@RestController
public class CloudProviderApplication {

  public static void main(String[] args) {
    //SpringApplication.run(CloudProviderApplication.class, args);
    Scanner scan = new Scanner(System.in);
    String port = scan.nextLine();
    new SpringApplicationBuilder(CloudProviderApplication.class).properties("server.port=" + port).run(args);
  }

  @RequestMapping("/")
  public String index(HttpServletRequest request) {
    return request.getRequestURL().toString();
  }
}

三、服務(wù)調(diào)用者

1、創(chuàng)建項(xiàng)目

IDEA中創(chuàng)建一個新的SpringBoot項(xiàng)目,除了名稱為“cloud-invoker”,其它步驟和上面創(chuàng)建服務(wù)器端一樣。

2、修改配置application.yml

server:
 port: 9000
spring:
 application:
  name: cloud-invoker
eureka:
 instance:
  hostname: localhost
 client:
  serviceUrl:
   defaultZone: http://localhost:8761/eureka/

3、修改啟動類代碼CloudInvokerApplication.java

增加注解@EnableDiscoveryClient。

package com.example.cloudinvoker;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableDiscoveryClient
public class CloudInvokerApplication {

  public static void main(String[] args) {
    SpringApplication.run(CloudInvokerApplication.class, args);
  }

}

4、配置Ribbon有2種方式:使用代碼、使用配置文件

方式一:使用代碼

(1)新建一個自定義負(fù)載規(guī)則類MyRule.java

Ribbon的負(fù)載均衡器接口定義了服務(wù)器的操作,主要是用于進(jìn)行服務(wù)器選擇。

調(diào)用ILoadBalancer的getAllServers方法可以返回全部服務(wù)器,這里只返回第一個服務(wù)器。

package com.example.cloudinvoker;

import com.netflix.loadbalancer.ILoadBalancer;
import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.Server;

import java.util.List;

public class MyRule implements IRule {

  private ILoadBalancer iLoadBalancer;

  @Override
  public Server choose(Object o) {
    List servers = iLoadBalancer.getAllServers();
    System.out.println("自定義服務(wù)器規(guī)則類,輸出服務(wù)器信息:");
    for(Server s: servers){
      System.out.println(" " + s.getHostPort());
    }
    return servers.get(0);
  }

  @Override
  public void setLoadBalancer(ILoadBalancer iLoadBalancer) {
    this.iLoadBalancer = iLoadBalancer;
  }

  @Override
  public ILoadBalancer getLoadBalancer() {
    return this.iLoadBalancer;
  }
}

(2)新建一個Ping類MyPing.java

負(fù)載均衡器中提供了Ping機(jī)制,每隔一段時間去Ping服務(wù)器,判斷服務(wù)器是否存活。

該工作由IPing接口的實(shí)現(xiàn)類負(fù)責(zé)。

package com.example.cloudinvoker;

import com.netflix.loadbalancer.IPing;
import com.netflix.loadbalancer.Server;

public class MyPing implements IPing {

  @Override
  public boolean isAlive(Server server) {
    System.out.println("自定義Ping類,服務(wù)器信息:" + server.getHostPort() + ",狀態(tài):" + server.isAlive());
    return true;
  }
}

(3)新建配置類MyConfig.java

package com.example.cloudinvoker.config;

import com.example.cloudinvoker.MyPing;
import com.example.cloudinvoker.MyRule;
import com.netflix.loadbalancer.IPing;
import com.netflix.loadbalancer.IRule;
import org.springframework.context.annotation.Bean;

public class MyConfig {
  @Bean
  public IRule getRule(){
    return new MyRule();
  }
  @Bean
  public IPing getPing(){
    return new MyPing();
  }
}

(4)新建配置類CloudProviderConfig.java

package com.example.cloudinvoker.config;

import org.springframework.cloud.netflix.ribbon.RibbonClient;

@RibbonClient(name = "cloud-provider", configuration = MyConfig.class)
public class CloudProviderConfig {
}

方式二:使用配置文件

把方式一的兩個配置類注釋掉,在application.yml的最后面添加下面配置

cloud-provider:
 ribbon:
  NFLoadBalancerRuleClassName: com.example.cloudinvoker.MyRule
  NFLoadBalancerPingClassName: com.example.cloudinvoker.MyPing
  listOfServers: http://localhost:8080/,http://localhost:8081/

5、添加控制器 InvokerController.java

package com.example.cloudinvoker;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

@RestController
@Configuration
public class InvokerController {

  @LoadBalanced
  @Bean
  public RestTemplate getRestTemplate(){
    return new RestTemplate();
  }

  @RequestMapping(value="/router", method = RequestMethod.GET,produces = MediaType.APPLICATION_JSON_VALUE)
  public String router(){
    RestTemplate restTemplate = getRestTemplate();
    //根據(jù)名稱調(diào)用服務(wù)
    String json = restTemplate.getForObject("http://cloud-provider/", String.class);
    return json;
  }
}

四、測試

1、啟動服務(wù)器端。

2、啟動兩個服務(wù)提供者,在控制臺中分別輸入8080和8081啟動。

3、啟動服務(wù)調(diào)用者。

4、瀏覽器訪問http://localhost:9000/router,多次刷新頁面,結(jié)果都是:

http://localhost:8081/

服務(wù)調(diào)用者項(xiàng)目IDEA控制臺定時輸出:

自定義服務(wù)器規(guī)則類,輸出服務(wù)器信息:
 localhost:8081
 localhost:8080
自定義Ping類,服務(wù)器信息:localhost:8081,狀態(tài):true
自定義Ping類,服務(wù)器信息:localhost:8080,狀態(tài):true

關(guān)于SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


標(biāo)題名稱:SpringCloud中怎么實(shí)現(xiàn)Ribbon負(fù)載均衡
文章分享:http://weahome.cn/article/iepedj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部