工作原理流程图
data:image/s3,"s3://crabby-images/6fef9/6fef9643c7671c8ada6b41b4b208e750a924249a" alt=""
上代码
common中添加依赖:
XML
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
创建feign的调用客户端:
data:image/s3,"s3://crabby-images/76359/763594504edc4d77b3ebaa1b0042dbc084d473ec" alt=""
java
@FeignClient("work-service") // 告诉springcloud容器,本接口为调用远程服务的service组件(声明式客户端远程调用)
public interface WorkMicroServiceFeign {
@PostMapping("/resume/init")
public GraceJSONResult init(@RequestParam("userId") String userId);
}
不通过feign也可以直接通过注册中心手动拉取列表,来进行远程调用,feign只不过帮我们封装的更好,调用更简单,简化了更多代码。
data:image/s3,"s3://crabby-images/5522f/5522fd405062c1890eb41c600af8b8b0d7665df5" alt=""
注入feign客户端并且进行微服务调用:
data:image/s3,"s3://crabby-images/50213/50213b77e8c1a64b1e77743a32f709e16ef88123" alt=""
data:image/s3,"s3://crabby-images/bfdcd/bfdcda4761ee27e53a5a5d630843da9c943a580d" alt=""