アイデアビルドSpringCloud(4)------ Feignを使用して負荷分散を実現

なぜFeignが現れるのですか?ロードバランシングの前にリボンはありませんか?

以前に実装した負荷分散では、Ribbon + RestTemplateを使用し、コントローラーでRestTemplateを使用して、URLに従ってサービスプロバイダーにアクセスしますが、通常は、コントローラーで宣言されたサービスインスタンスを呼び出して、ロジックを呼び出します。これは、に準拠していません。私たちは通常プログラミング仕様に直面しているので、偽物の出現はこの仕様の問題を解決することです。

私たちはまだ前のプロジェクトに基づいており、eureka-server-consumer-feignという名前の新しいモジュールを作成し、pom.xmlにfeign、ribbon、eurekaの依存関係を追加します

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-feign</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-ribbon</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

新しいサービスパッケージを作成し、その中に新しいITestServiceインターフェイスを作成して、@ FeignClientアノテーションを追加します。name属性は、サービスが呼び出すサービスプロバイダーのセットです。

@FeignClient(name = "EUREKA-SERVER-PROVIDER")
public interface ITestService {

    @RequestMapping("/provider/test")
    String test();
}

コントローラにITestServiceを導入します。

@RestController
public class ConsumerController {

    @Autowired
    private ITestService iTestService;

    @RequestMapping("/consumer/test3")
    public String test3(){
        return iTestService.test();
    }

}

スタートアップクラスに加えて、@ EnableFeignClientsアノテーション、@ EnableEurekaClientアノテーション、@ EnableDiscoveryClientアノテーション:

@SpringBootApplication
@EnableFeignClients
@EnableEurekaClient
@EnableDiscoveryClient
public class EurekaServerConsumerFeignApplication {

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

}

構成ファイルapplication.yml:

server:
  port: 80

eureka:
  client:
    register-with-eureka: false
    service-url:
      defaultZone: http://localhost:7001/eureka/,http://localhost:7002/eureka/,http://localhost:7003/eureka/

Eurekaクラスター7001、7002、7003、サービスプロバイダー8001、8002、8003、そして私たちの上の消費者のふりを開始します 

負荷分散もfeignを使用して正常に実装されていることが判明しました。実際、Ribbonの機能はfeignに統合されています。

 

 

 

 

 

 

おすすめ

転載: blog.csdn.net/weixin_37689658/article/details/88603101