SpringCloudAlibaba微服务调用组件 |
您所在的位置:网站首页 › 微服务与微服务之间的调用 › SpringCloudAlibaba微服务调用组件 |
SpringCloudAlibaba微服务调用组件-Feign
本项目代码与笔记已存放在Gitee仓库 地址: 代码,笔记 文章目录 SpringCloudAlibaba微服务调用组件-Feign1. 什么是Feign1.1 优势 2. Spring Cloud Alibaba快速整合OpenFeign1)引入依赖2)编写调用接口+@FeignClient注解3)调用端在启动类上添加@EnableFeignClients注解(不加的话会找不到客户端service)4)发起调用,像调用本地方式一样调用远程服务 3. Spring Cloud Feign的自定义配置及使用3.1 日志配置3.2 契约配置 (可以把openFeign还原为feign使用feign的原生注解)3.3 超时时间配置3.4自定义拦截器实现认证逻辑 JAVA 项目中如何实现接口调用?1)Httpclient HttpClient 是 Apache Jakarta Common 下的子项目,用来提供高效的、最新的、功能丰富的支持 Http 协议的客户端编程工具包,并且它支持 HTTP 协议最新版本和建议。HttpClient 相比传统 JDK 自带的 URLConnection,提升了易用性和灵活性,使客户端发送 HTTP 请求变 得容易,提高了开发的效率。 2)Okhttp 一个处理网络请求的开源项目,是安卓端最火的轻量级框架,由 Square 公司贡献,用于替代 HttpUrlConnection 和 Apache HttpClient。OkHttp 拥有简洁的 API、高效的性能,并支持多种协议(HTTP/2 和 SPDY)。 3)HttpURLConnection HttpURLConnection 是 Java 的标准类,它继承自 URLConnection,可用于向指定网站发送GET 请求、POST 请求。HttpURLConnection 使用比较复杂,不像 HttpClient 那样容易使用。 4)RestTemplate WebClient RestTemplate 是 Spring 提供的用于访问 Rest 服务的客户端,RestTemplate 提供了多种便捷访问远程 HTTP 服务的方法,能够大大提高客户端的编写效率。上面介绍的是最常见的几种调用接口的方法,我们下面要介绍的方法比上面的更简单、方便,它就是 Feign。 1. 什么是FeignFeign是Netflix开发的声明式、模板化的HTTP客户端**(feign是声明在服务消费端的)**,其灵感来自Retrofit、JAXRS-2.0以及 WebSocket。Feign可帮助我们更加便捷、优雅地调用HTTP API。Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。 Spring Cloud openfeign对Feign进行了增强,使其支持Spring MVC注解,另外还整合了 Ribbon和Nacos,从而使得Feign的使用更加方便 。 1.1 优势Feign可以做到使用 HTTP 请求远程服务时就像调用本地方法一样的体验,开发者完全感知不到这是远程方法,更感知不到这是个 HTTP 请求。它像 Dubbo 一样,consumer 直接调用接口方法调用 provider,而不需要通过常规的 Http Client 构造请求再解析返回数据。它解决了让开发者调用远程接口就跟调用本地方法一样,无需关注与远程的交互细节,更无需关注分布式环境开发。 2. Spring Cloud Alibaba快速整合OpenFeign 1)引入依赖 org.springframework.cloud spring-cloud-starter-openfeign 2)编写调用接口+@FeignClient注解 /** * Create with IntelliT IDEA * * @Author: zhengmingzhe * @Date: 2023/03/15/21:15 * @Description: 调用stock-service服务service */ /*name 指定调用的rest接口的服务名,比如这里调用库存服务stock-service * path 指定rest接口所在的StockController指定的@RequestMapping("/stock") * **/ @FeignClient(name = "stock-service", path = "/stock") public interface StockFeignService { //声明需要调用的rest接口对应的方法,直接复制过来,对应的就行(不用写实现类) @RequestMapping("/reduct") String reduct(); } 3)调用端在启动类上添加@EnableFeignClients注解(不加的话会找不到客户端service) @SpringBootApplication @EnableDiscoveryClient //启动nacos的客户端 不加也行在后续的版本这个注解可不用手动添加 @EnableFeignClients public class OrderApplication { public static void main(String[] args) { SpringApplication.run(OrderApplication.class, args); } } 4)发起调用,像调用本地方式一样调用远程服务 @RestController @RequestMapping("/order") public class OrderController { @Autowired StockFeignService stockService; @RequestMapping("/add") public String add() { System.out.println("下单成功"); String msg = stockService.reduct(); return "Hello Feign!" + msg; } } 3. Spring Cloud Feign的自定义配置及使用Feign 提供了很多的扩展机制,让用户可以更加灵活的使用。 3.1 日志配置有时候我们遇到 Bug,比如接口调用失败、参数没收到等问题,或者想看看调用性能,就需要 配置 Feign 的日志了,以此让 Feign 把请求信息输出来。 1)定义一个配置类,指定日志级别 /* 全局配置:当使用@Configuation会将配置作用于所有的服务提供方 * 局部配置: 如果只想针对某一个服务进行配置,就不要加@Configuration */ @Configuration public class FeignConfig { /** * 日志级别 ** @return */ @Bean public Logger.Level feignLoggerLevel() { return Logger.Level.BASIC; } } 通过源码可以看到日志等级有 4 种,分别是: NONE【性能最佳,适用于生产】:不记录任何日志(默认值)。 BASIC【适用于生产环境追踪问题】:仅记录请求方法、URL、响应状态代码以及 执行时间。 HEADERS:记录BASIC级别的基础上,记录请求和响应的header。 FULL【比较适用于开发及测试环境定位问题】:记录请求和响应的header、body 和元数据。 2) 局部配置,让调用的微服务生效,在@FeignClient 注解中指定使用的配置类(如果是全局配置就不用加) @FeignClient(name = "stock-service", path = "/stock", configuration = FeignConfig.class) public interface StockFeignService { //声明需要调用的rest接口对应的方法,直接复制过来,对应的就行(不用写实现类) @RequestMapping("/reduct") String reduct(); }3) 在yml配置文件中执行 Client 的日志级别才能正常输出日志,格式是"logging.level.feign接口包路径 =debug" (找到对应的service所在的包右键copy reference) logging: level: com.zmz.order.feign: debug就会显示BASIC级别的日志信息 下单成功 2023-03-15 22:39:48.867 DEBUG 23504 — [nio-8040-exec-1] com.zmz.order.feign.StockFeignService : [StockFeignService#reduct] —> GET http://stock-service/stock/reduct HTTP/1.1 2023-03-15 22:39:48.871 DEBUG 23504 — [nio-8040-exec-1] com.zmz.order.feign.StockFeignService : [StockFeignService#reduct] //声明需要调用的rest接口对应的方法,直接复制过来,对应的就行(不用写实现类) // @RequestMapping("/reduct") // String reduct(); @RequestLine("GET/reduct") // @RequestLine替换@RequestMapping加上请求方式GET String reduct(); } 3)补充,也可以通过yml配置契约 #feign日志局部配置 feign: client: config: stock-service: loggerLevel: FULL contract: feign.Contract.Default #设置为默认的契约(还原成原生注解) 3.3 超时时间配置通过 Options 可以配置连接超时时间和读取超时时间,Options 的第一个参数是连接的超时 时间(ms),默认值是 2s;第二个是请求处理的超时时间(ms),默认值是 5s。 /*设置feign调用超时时间*/ @Bean public Request.Options options() { return new Request.Options(5000, 10000); }yml中配置 feign: client: config: stock-service: loggerLevel: FULL contract: feign.Contract.Default #设置为默认的契约(还原成原生注解) connectTimeout: 5000 readTimeout: 3000补充说明: Feign的底层用的是Ribbon,但超时时间以Feign配置为准 3.4自定义拦截器实现认证逻辑在消费端调用提供端的时候起作用(要验证认证Authorization的时候把feign日志级别设置为FULL) public class FeignAuthRequestInterceptor implements RequestInterceptor { Logger logger = LoggerFactory.getLogger(this.getClass()); @Override public void apply(RequestTemplate template) { logger.info("feign拦截器----"); // 业务逻辑 String access_token = UUID.randomUUID().toString(); template.header("Authorization", access_token); } } //@Configuration public class FeignConfig { /** * 日志级别 ** @return */ @Bean public Logger.Level feignLoggerLevel() { return Logger.Level.FULL; } /*定义拦截器*/ @Bean public FeignAuthRequestInterceptor feignAuthRequestInterceptor() { return new FeignAuthRequestInterceptor(); } } |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |