5.Spring Cloud Alibaba教程:Nacos整合Feign

概述

Feign是一个声明式的http客户端。使用Feign只需要创建接口并加上对应的注解,就可以实现类似RestTemplate方式的调用,只是它将底层的http请求代码隐藏起来。另外,Feign默认集成了Ribbon,Nacos也可以很好地兼容Feign,具备负载均衡的功能。

注:本文的代码是基于前2篇Nacos的代码基础上,继续添加的功能

引入依赖

在consumer服务加入以下依赖:

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

增加注解@EnableFeignClients

在ConsumerApplication启动类启动类加上 @EnableFeignClients

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class ConsumerApplication {
    
    
    public static void main(String[] args) {
    
    
        SpringApplication.run(ConsumerApplication.class, args);
    }
}

创建Service

  • 创建接口HelloService

  • 加上注解 @FeignClient,指定value属性,值为nacos显示的provider服务名称
    在这里插入图片描述

  • 加上echo方法,调用provider的接口。

  • 代码也很简单,如下:

@FeignClient(value = "test-provider")
public interface HelloService {
    
    

    @GetMapping("/echo/{name}")
    public String echo(@PathVariable String name);
}

调用Service

  • consumer的controller增加一个接口进行测试
@RestController
public class HelloController {
    
    

    @Autowired
    private HelloService helloService;

    @GetMapping("/echo/feign/{name}")
    public String echoFeign(@PathVariable String name){
    
    
        return helloService.echo(name);
    }
}

测试

分别运行provider和consumer,然后postman访问http://localhost:8020/echo/feign/lisi
在这里插入图片描述

Feign负载均衡

创建provider-2

将provider的bootstrap.properties复制一份,命名为bootstrap-2.properties。跟bootstrap.properties不一样的只有spring.application.name属性,内容如下:

spring.application.name=test-provider-config-2
spring.cloud.nacos.config.server-addr=192.168.25.131:8848
spring.cloud.nacos.config.file-extension=yaml

因此,Nacos配置也需要加上test-provider-config-2.yaml。内容和test-provider-config.yaml基本一样,将里面的端口号改成8011就行了。

在这里插入图片描述
Idea加上ProviderApplication-2的启动配置,active profiles=2
在这里插入图片描述
把provider、provider-2、consumer全都启动起来

在这里插入图片描述

测试负载均衡

postman继续访问上一步feign的测试接口,会看到provider输出的端口号轮询变化,因为默认采用的是轮询负载均衡策略。
在这里插入图片描述
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_28834355/article/details/108815593