概述
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@EnableFeignClientspublic 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增加一个接口进行测试@RestControllerpublic class HelloController {@Autowiredprivate 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-2spring.cloud.nacos.config.server-addr=192.168.25.131:8848spring.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输出的端口号轮询变化,因为默认采用的是轮询负载均衡策略。