[Spring cloud 一步步实现广告系统] 11. 使用Feign实现微服务调用
2019-08-04 23:09
1406 查看
上一节我们使用了Ribbon(基于
Http/Tcp)进行微服务的调用,Ribbon的调用比较简单,通过Ribbon组件对请求的服务进行拦截,通过
Eureka Server获取到服务实例的
IP:Port,然后再去调用API。本节课我们使用更简单的方式来实现,使用声明式的
Web服务客户端
Feign,我们只需要使用Feign来声明接口,利用
注解来进行配置就可以使用了,是不是很简单?实际工作中,我们也只会用到Feign来进行服务之间的调用(大多数)。接下来,我们来实例操作一把。
为了代码的重用性,我们来创建一个新的project
mscx-ad-feign-sdk作为Feign的服务调用工具。
- 创建项目
mscx-ad-feign-sdk
-
三部曲之Step 1(加依赖)
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactId>mscx-ad</artifactId> <groupId>com.sxzhongf</groupId> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <packaging>jar</packaging> <name>mscx-ad-feign-sdk</name> <description>只定义微服务Feign调用用到的请求对象和响应对象,而不涉及具体的实现类。</description> <groupId>com.sxzhongf</groupId> <artifactId>mscx-ad-feign-sdk</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- 引入服务调用的组件 feign 依赖--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>com.sxzhongf</groupId> <artifactId>mscx-ad-common</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <!-- 引入系统容错hystrix 的依赖--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> <version>1.2.7.RELEASE</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
-
三部曲之Step 2(加注解
@EnableFeignClients
,添加在具体的微服务中,使用我们自定义的FeignClient)/** * ISponsorFeignClient for service using * * @author <a href="mailto:magicianisaac@gmail.com">Isaac.Zhang | 若初</a> */ @FeignClient(value = "mscx-ad-sponsor", fallback = SponsorClientHystrix.class) public interface ISponsorFeignClient { @RequestMapping(value = "/ad-sponsor/plan/get", method = RequestMethod.POST) CommonResponse<List<AdPlanVO>> getAdPlansUseFeign(@RequestBody AdPlanGetRequestVO requestVO); @RequestMapping(value = "/ad-sponsor/user/get", method = RequestMethod.GET) /** * Feign 埋坑之 如果是Get请求,必须在所有参数前添加{@link RequestParam},不能使用{@link Param} * 会被自动转发为POST请求。 */ CommonResponse getUsers(@RequestParam(value = "username") String username); }
相关文章推荐
- [Spring cloud 一步步实现广告系统] 10. 使用Ribbon 实现微服务调用
- [Spring cloud 一步步实现广告系统] 配置项目结构 & 实现Eureka服务
- Spring Cloud的Eureka实现服务发现注册和Feign实现服务调用
- Spring Cloud在一个服务中使用Feign远程调用另一个服务
- [Spring cloud 一步步实现广告系统] 5. 投放系统配置+启动+实体类
- Spring Cloud版——电影售票系统<四>使用Hystrix实现微服务的容错处理
- [Spring cloud 一步步实现广告系统] 9. 主类和配置文件
- Spring Cloud(十二)声名式服务调用:Feign 的使用(下)
- [Spring cloud 一步步实现广告系统] 3. 网关路由
- [Spring cloud 一步步实现广告系统] 4. 通用代码模块设计
- Spring Cloud版——电影售票系统<三>使用Feign实现声明式REST调用
- Spring Cloud中使用声明式服务(Feign)调用文件上传服务
- [Spring cloud 一步步实现广告系统] 7. 中期总结回顾
- springcloud使用feign实现服务间条用,参数数据太大,无法调用成功解决方法
- spring cloud-使用feign来消费Restful服务同时加入Ribbon来实现负载均衡
- [Spring cloud 一步步实现广告系统] 4. 通用代码模块设计
- 如何使用Spring Cloud – 简单服务流程(服务发现与API调用)
- 使用kernel编译+busybox定制Linux系统--实现ssh远程登录+web服务的迷你主机
- B/S(WEB)系统中使用Activex插件调用扫描仪实现连续扫描并上传图像(IE文件扫描并自动上传)
- [Android开发入门]调用系统服务之Manager的使用(一)