前言
上一篇练SpringCloud第一篇:Nacos安装与使用学习了Nacos,有了服务注册中心,有了配置管理和服务管理。接下来学习OpenFeign进行服务间远程调用,不再是直接利用RestTemplate发起HTTP请求进行调用,而是声名式进行服务调用。
一、服务提供者和服务消费者
上一篇中创建了两个服务,一个是provider服务,一个是consumer服务。由consumer调用provider提供的服务。启动后可以在nacos后台看到:
1. 假如provider服务有一个hello接口,代码如下:
@RestController
public class DemoController {
@GetMapping("hello")
public String hello() {
return "Hello world!";
}
}
2. 在consumer服务中添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>3.1.1</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
<version>3.1.1</version>
</dependency>
在consumer启动类上加@EnableFeignClients
注解,如下:
@EnableDiscoveryClient
@SpringBootApplication
@EnableFeignClients
public class DemoConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(DemoConsumerApplication.class, args);
}
}
3. 声名需要调用的接口
在consumer服务中创建如下接口(DemoProviderClient) :
@FeignClient(value = "demo-provider")
public interface DemoProviderClient {
@GetMapping("hello")
String hello();
}
PS:在工作中,此接口应拆成一个api项目,方便部署到maven私服,以供其他服务进行引入调用。
@FeignClient
注解标识此接口为需要调用的服务接口类,value值为provider服务配置中${spring.application.name}
的值(默认情况下)。- hello接口方法需要跟provider中hello方法参数、名称等保持一致。
二、服务调用
上面声名好了要调用的服务,使用时直接像本地服务调用一样,例如在consumer服务的控制器中:
@RestController
public class DemoController {
// 这里注入DemoProviderClient
@Resource
private DemoProviderClient demoProviderClient;
@GetMapping("hello")
public String hello() {
// 直接调用
return demoProviderClient.hello();
}
}
接下来访问这个接口,http://localhost:8081/hello(8081是consumer服务的启动端口),结果如下:
这样就调用成功了。
三、结语
OpenFeign的用法远远不止这样,还有很多用途。这里用于微服务中进行服务间调用,只是用法之一。例如用于普通的客户端请求,它的声名式优点就凸显出来了。