概述
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输出的端口号轮询变化,因为默认采用的是轮询负载均衡策略。