Feign是简化Java HTTP客户端开发的工具(java-to-httpclient-binder),它的灵感来自于Retrofit、JAXRS-2.0和WebSocket。Feign的初衷是降低统一绑定Denominator到HTTP API的复杂度,不区分是否为restful。
开发人员使用Jersey和CXF等工具可以方便地编写java client,从而提供REST或SOAP服务;开发人员也可以基于Apache HC等http传输工具包编写自己的java http client;而Feign的关注点在于简化开发人员使用工具包的复杂度,以最少的代码编写代码从而提供java http客服端。通过定制解码器和异常处理,开发人员可以任意编写文本化的HTTP API。
好了,上面是官方的,假如要我说Feign是什么。
可以理解为Feign是一个超级方便的调用Spring-Cloud远程服务的框架/工具,帮助开发者以更少耦合更少代码更快更兼容的方法进行远程服务调用。
调用的时候,双方的application.yml一定要加上两个配置,因为双方服务器是需要相互发现并获取服务列表的。
不然会报错提示“feign Load balancer does not have available server for client: xxxx”
eureka:
client:
#是否将自己注册到eureka服务注册中心,默认为true
register-with-eureka: true
#是否从服务注册中心获取可用的服务清单,默认为true
fetch-registry: true
serviceUrl:
defaultZone: http://192.168.114.152:9091/eureka/
然后就是再pom.xml里面加上最新出炉的feign包
<dependency>
<groupId>org.springframework.cloudgroupId>
<artifactId>spring-cloud-starter-feignartifactId>
<version>1.4.4.RELEASEversion>
dependency>
启动器一定要加@EnableFeignClients,代表进行Feign调用,Feign会到Eureka拉取服务列表,供调用的。
@EnableEurekaClient
@SpringBootApplication
@EnableFeignClients
public class CheckCollectSysApplication {
public static void main(String[] args) {
SpringApplication.run(CheckCollectSysApplication.class,args);
}
}
调用方业务方面。推荐是写一个interface类,把方法封装起来供其他Controller调用。
这里要注意
1. @FeignClient里面一定要指定是name,很久以前的版本指定的是serviceId,那个已经过时了。
2. 如果用到占位符,@PathVariable也需要指定value,这是一个强制要求,不然会报错,提示“Feign PathVariable annotation was empty on param 0.”
3. RequestParam也需要指定value,不然会提示”RequestParam.value() was empty on parameter 1”
另外,别人说什么GetMapping啊PutMapping啊不行的,其实不会的,我试过都可以了
@FeignClient(name = "demo-checksys")
public interface ChecysysRemoteClient {
/**
* 获取基本信息
*(PutMapping的URL=远程项目的Path+ControllerPath+MethodPath
* 简单的说,就是你直接postman可以访问的项目路径)
*/
@PutMapping("/checksys/register/info/{checkNum}")
public ApiReturnObject updateCheckRegisterByBodyCheck(@PathVariable(value="checkNum") String checkNum,@RequestParam(value="bodyJson") String bodyJson);
}
这里的FeignClient的name是指注册到Eureka的被调用者的ApplicationName,就是你应用的名字啦,application.yml里面可以进行配置
spring:
application:
name: demo-checksys
PutMapping的URL=远程项目的Path+ControllerPath+MethodPath,简单的说,就是你直接postman可以访问的项目路径。
例如项目是http://127.0.0.1:8080/demo/user/getUser/{userId},
那么这里写的就是”/demo/user/getUser/{userId}”
至于被调用者,一如既往的code,没什么不同,毕竟是被别人调用,这种调用方式很安逸。
/**
* 获取基本信息
*/
@PutMapping("/info/{checkNum}")
public ApiReturnObject updateCheckRegisterByBodyCheck(@PathVariable String checkNum,String bodyJson) {
//这里可以打印一些日志
outSystemService.updateCheckRegisterByBodyCheck(checkNum, bodyJson);
return ApiReturnUtil.success("调用成功");
}