1. OpenFeign是什么?
在微服务架构中,Spring Cloud OpenFeign通过将OpenFeign集成到服务中的方式,为服务之间的调用提供了解决方案。
OpenFeign可以做到通过HTTP请求的方式调用远程服务,就像调用本地方法一样。
2. 配置OpenFeign
2.1 配置pom.xml
OpenFeign的依赖包:
<!--openfeign -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.2 三个角色
通过OpenFeign调用远程服务时,主要有三个角色:服务消费者,服务提供者,服务提供者的Feign接口。
2.2.1 服务消费者
启动类:
@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients("com.supergo") //扫面启用feign客户端
public class ConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerApplication.class, args);
}
}
其中最重要的是@EnableFeignClients注解,该注解会扫描包中的feign客户端,并将其注入到spring容器中。但该注解默认扫描的是该包以及下属包中的feign,当项目很大时,对包可能会按功能来分类,所以我一般指定它要扫描的包,在此处即 "com.supergo"包。
controller:
@RestController
@RequestMapping("/test")
public class ConsumerController {
@Autowired
private ConsumerApi consumerApi;
@RequestMapping("/consumertest")
public String consumerTest(){
return consumerApi.takeProvider();
}
}
其中的 ConsumerApi 即服务提供者的feign接口。
2.2.2 feign接口
feign接口可看作是中间者,不需要启动微服务。
@FeignClient(name = "service-provider") //指定服务提供者
public interface ConsumerApi {
@RequestMapping("/api/takeprovider")
public String takeProvider();
}
这里的 @RequestMapping即是指定服务之间调用的路径。
如果项目中不适用Eureka注册中心,也可以通过url的方式指定服务提供者:
// url可在配置文件中配置
@FeignClient(name = "ChatRecordApi", url = "${clink.app.clink2-chat-record.url}")
2.2.3服务提供者
@RestController
@RequestMapping("/api")
public class ProviderController {
@RequestMapping("/takeprovider")
public String serviceProvide(){
return "下游服务被调用";
}
}
2.3 测试