Feign说明
Feign是一种声明式、模板化的HTTP客户端。在spring cloud中使用Feign,可以做到类似于普通的接口的请求调用,可以发现对应的服务的接口,进而直接调用对应服务中的接口。
引入依赖,启动类开启客户端
首先需要在各个微服务中引入依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
然后在启动类中加入注解@EnableFeignClients ,开启Feign客户端。
在各自的启动类中添加注释:@EnableDiscoveryClient 和 @EnableFeignClients ,并在配置文件中添加各自的服务名,以及配置Nacos的服务地址
//服务A的启动类
@EnableDiscoveryClient //nacos注册
@EnableFeignClients //Feign 服务调用
@SpringBootApplication
public class ApplicationA {
public static void main(String[] args){
SpringApplication.run(ApplicationA.class,args);
}
}
//服务B的启动类
@EnableDiscoveryClient //nacos注册
@EnableFeignClients //Feign 服务调用
@SpringBootApplication
public class ApplicationB {
public static void main(String[] args){
SpringApplication.run(ApplicationB.class,args);
}
}
application.properties
服务A配置
# 服务端口
server.port=8001
# 服务名
spring.application.name=serviceA
# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
--------------------------服务B配置-------------------------------
# 服务端口
server.port=8003
# 服务名
spring.application.name=serviceB
# nacos服务地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
3.在微服务A中创建client包和接口
然后在当前服务内编写Feign接口,接口与普通的controller层类似,只是在类上不需要写@Controller等注解,只需要加上@Component 、 @FeignClient注解即可,下面的请求方法需要写上请求方式(根据提供服务的接口适配)@PostMapping(“/findList”)注解。如下:
@Component
@FeignClient(value = "sso", path = "/api/user", fallback = UserClientHystrix.class)//value是需要调用的服务名称,path是sso服务内的请求路径
//value必选是服务名(就是yaml中server.name)
//path是前缀(就是yaml中server.contentPath)
//fallback是服务熔断的类
public interface UserClient {
/**
* 获取对象集合
* @param object
* @return
*/
@PostMapping("/findList")//根据服务适配添加注解
Result<UserDO> findList(@CustomJSONBody Object object);
}
//@FeignClient注解用于指定从哪个服务中调用功能 ,名称与被调用的服务名保持一致。
在微服务A中创建client包和接口
@Component
@FeignClient("serviceB")
public interface ServiceBClient {
@PostMapping("serviceB/test")
public Result test(@RequestParam String args);
}
注意微服务A(调用者)中ServiceBClient接口中编写的是微服务B中被调用的接口,参数类型方法名要一致。以下时微服务B中被调用的接口(Controller)
服务B中接口的示例
@RestController
@RequestMapping("serviceB")
@CrossOrigin
public class VodController {
@PostMapping("test")
public void test(@RequestParam String args){
System.out.println(args);
}
}
4.在微服务A中调用服务B的接口
@Autowired
private ServiceBClient serviceBClient ; //首先使用Autowired注解进行Client的自动装配
serviceBClient.test("陈杰");// 对服务B中的额接口进行调用
方法总结
在微服务A中调用服务B中的接口
1.初始化操作:添加依赖,配置等等。。。
2.创建Client接口,使用@GetMapping注解对被调用的微服务进行地址映射。
3.在微服务A中调用Client接口中的方法。
注:① 接口层添加注解@FeignClient,并在注解中指明属性value="服务提供方的实例名";
② 在方法上添加映射的URL要与服务提供方接口的URL一致;