SpringCloud openfeign声明式服务调用实现方法介绍
作者:幽默涵养miss u
一、介绍
OpenFeign是一种声明式、模板化的HTTP客户端(仅在Application Client中使用)(称OpenFeign作用:声明式服务调用)。声明式调用是指,就像调用本地方法一样调用远程方法,无需感知操作远程http请求。OpenFeign替换RestTemplate。
二、使用
(1)导入依赖
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.12.RELEASE</version> </parent> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Hoxton.SR12</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> </dependencies>
(2)在启动类上添加扫描注解
/** * EnableFeignClients - 开启Openfeign技术。让spring cloud扫描Openfeign相关注解, * 生成动态代理实现对象。 * 可选属性 basePackages = {"feign接口所在包1", "feign接口所在包2"} * 默认扫描当前类型所在包,及所有子孙包。 */ @SpringBootApplication @EnableEurekaClient @EnableFeignClients(basePackages = {"com.bjsxt.feign"}) public class OpenFeignAppClientApp { public static void main(String[] args) { SpringApplication.run(OpenFeignAppClientApp.class, args); } }
(3)编写本地接口
/** * 定义接口,基于注解,实现声明式远程服务调用。 * 技术是OpenFeign。 * 需要确定的事情: * 1. 访问的远程服务名称是什么。 * 2. 访问的远程服务具体地址是什么。 * 3. 访问的远程服务请求方式是什么。 * 4. 访问的远程服务,参数是什么。 * 5. 访问的远程服务,返回结果类型是什么。 * * FeignClient - 代表当前的接口是一个OpenFeign客户端,要访问远程的服务。 * 具体的实现类对象,由spring cloud动态生成代理对象来实现。 * 必要属性: value - 要访问的远程服务命名是什么。 */ @FeignClient("application-service") public interface AppServiceOpenfeignClient { /** * 定义方法。使用SpringMVC注解+方法定义,实现远程服务访问规则定义。 * 建议写法: 找到要访问的控制器。复制对应的方法签名即可。 * * GetMapping - 约束了请求方式 * 注解属性value - 约束了请求的具体地址 * 方法返回值 - 约束了远程服务返回结果类型 * 方法参数表 - 约束了远程服务的请求参数 */ @GetMapping("/getNoParams") public String getNoParams(); /** * post请求,无参数 * @return */ @PostMapping("/postNoParams") public String postNoParams(); }
(4)本地接口注意事项
形参需要添加对应注解如@RequestParam,@RequestBody,@PathVariable等。
三、通讯优化
(1)配置OpenFeign请求-应答的GZIP压缩
# 配置openfeign请求和应答的gzip压缩处理
feign:
compression:
request:
enabled: true # 开启请求压缩处理。默认false
min-request-size: 128 # 请求容量多少,开始压缩。默认2048字节
mime-types: text/html, text/xml, text/plain, text/css, application/json # 请求头content type是什么,做压缩处理
response:
enabled: true # 开启响应压缩处理。默认false
(2)Tomcat服务器GZIP优化配置
server:
compression:
enabled: true # 是否开启响应压缩处理。默认false
mime-types: text/html, text/xml, text/plain, text/css, text/javascript, application/javascript, application/json, application/xml # 响应content type什么类型,做压缩处理。
min-response-size: 128 # 响应容量多大,做压缩处理。 默认2048字节
到此这篇关于SpringCloud openfeign声明式服务调用实现方法介绍的文章就介绍到这了,更多相关SpringCloud openfeign内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!