Resilience4j 源码解析(1):简介及调试环境搭建

2023-10-24 09:59

本文主要是介绍Resilience4j 源码解析(1):简介及调试环境搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 简介
  2. 调试环境搭建
    2.1 安装设置 Gradle
    2.2 安装 Resilience4j
    2.3 运行
  3. 入手点
    3.1 代码结构
    3.2 代码量
    3.3 源码分析方法
  4. 小结
  5. 参考文档

相关文章:

  • Resilience4j 源码解析(1):简介及调试环境搭建
  • Resilience4j 源码解析(2):浅析框架设计原理
  • Resilience4j 源码解析(3):限流模块 RateLimiter 与 常见限流算法

1.简介

Resilience4j 是受Hystrix启发而做的新一代轻量级熔断器,基于Java8的函数式编程开发。

Resilience4j 只依赖一个Vavr包(函数式库),不需要再引入其他包,所以相对于Hystrix是轻量级的。同时resilience4j的模块化程度更好,很容易的扩展附加模块,同时也是学习如何组织模块化项目结构的一个绝佳范例。

目前Resilience4j包括熔断(CircuitBreaker)、限流(RateLimiter)、隔离(BulkHead)、重试(Retry)、缓存(Cache)、执行时间限制(TimeLimiter)等模块及一些附加模块(Add-on modules)。

2.调试环境搭建

2.1 安装及设置 Gradle

项目使用Gradle管理依赖包,调试环境里需要安装及设置Gradle,具体步骤,推荐阅读:Mac OS X 安装及配置 Gradle

2.2 安装 Resilience4j

github 地址:https://github.com/resilience4j/resilience4j

# 拉取源码
git clone https://github.com/resilience4j/resilience4j

拉取源码,即安装成功。
在这里插入图片描述

2.3 运行

源码分析前,一定要先运行试试,一般的开源产品都会有基准测试,再不济也会有单元测试。

我们先随便找一个模块试试看,比如,CircuitBreakerBenchmark
在这里插入图片描述
运行报错了! 没关系,开始查问题,于是按照网上说的:

  • 尝试安装了Idea的jmh插件,还是不行!?
  • 看到说gradle 5.5以上的jmh要用0.5.0版本,修改后报找不到,还是不行!?
  • 据说是缺包,于是增加了 jmh-core 和 ,还是不行!?
  • 再找,说要用gradle —stop 和 gradle --no-daemon jmh,还是不行!?

最后终于在 StackOverFlow 里搜索时,看到了下面这段话:
在这里插入图片描述
终于豁然开朗,打开IDE配置后,成功生效。

其实,正确的做法分两步:

一是配置编译插件。 编辑最外层的 build.gradle,找到编译处增加:

compile "org.openjdk.jmh:jmh-core:1.21"
compile "org.openjdk.jmh:jmh-generator-annprocess:1.21"

注意:如果是在test目录,可以使用testCompile,如果是在主目录,则需要使用compile。

二是打开IDE配置,开启Annotation Processors,路径如下:

Preferences -> Build,Excution,Deployment - > Compiler -> Annotation Processors

可能你以前配置过JMH,也不会报这个错,虽然这是个小错,但是充分证明了再开始源码研究前,运行一次是很有必要。

这时我们再运行基准测试和单元测试试试,基本没有报错。但实际上再仔细观察会发现,还是有错。没关系,其实也是给我们提了一个醒,开源框架要实际用到生产中,还有一段叫实践落地的路要走。这里先不分析错误,只是大致看一下,心里大致有个底就好。

3. 切入点

3.1 代码结构

源码分析少不了整体代码结构的分析,我们先来看看 Resilience4j 的整体代码结构,如下图:
在这里插入图片描述
手动数了一下,一共 32 个模块,我稍微整理了下,其中:

核心模块,有7个:

  • resilience4j-core: 一些通用核心接口定义
  • resilience4j-circuitbreaker: 模块:熔断
  • resilience4j-ratelimiter: 模块:限流
  • resilience4j-bulkhead: 模块:隔离(两种隔离:和线程池隔离)
  • resilience4j-retry: 自动重试,有同步或异步的两种机制
  • resilience4j-cache: 响应缓存,主要是扩展 circuitbreaker 模块
  • resilience4j-timelimiter: 超时处理,也是扩展 circuitbreaker 模块

扩展模块,有18个:

  • resilience4j-reactor: 实现对 Spring Reactor 的操作支持
  • resilience4j-rxjava2: 实现对 RxJava2 的操作支持
  • resilience4j-micrometer: Micrometer 指标支持
  • resilience4j-metrics: Dropwizard 指标支持
  • resilience4j-prometheus: Prometheus 监控报警系统指标支持
  • resilience4j-spring: Spring 支持
  • resilience4j-spring-boot: Spring Boot 1.X Starter集成,可不看
  • resilience4j-spring-boot2: Spring Boot 2.X Starter集成
  • resilience4j-spring-boot-common: Spring Boot 通用支持
  • resilience4j-spring-cloud: Spring Cloud 支持
  • resilience4j-spring-cloud2: Spring Cloud 2 支持
  • resilience4j-spring-cloud-common: Spring Cloud 通用支持
  • resilience4j-feign: 适配Spring Cloud的Feign
  • resilience4j-ratpack: http框架 Ratpack Starter 集成
  • resilience4j-retrofit: 适配Retrofit。一个网络加载框架。底层是使用OKHttp封装的
  • resilience4j-vertx: Vertx 框架支持
  • resilience4j-consumer: 官方说是 Circular Buffer Event 的 consumer,待分析
  • resilience4j-kotlin: 支持 Kotlin coroutines

其他模块,有8个:

  • resilience4j-all: hello world 例子
  • resilience4j-annotations: 核心模块功能使用的注解
  • resilience4j-bom: 空目录
  • resilience4j-circularbuffer: 没看出来在哪儿用
  • resilience4j-documentation: 文档说明
  • resilience4j-framework-common: 主要是一些自动配置ConfigurationProperties的支持
  • resilience4j-test: 没有写完的测试模块,估计是想要把测试放在一起吧

除去划线的,剩下的就是接下来要分析的相关模块,从重点模块开始发散开来。

3.2 代码量

在这里插入图片描述
从图中我们可以看到,代码总行数:6w+。对于一个框架来说,的确算少的,像jodd一个基础java工具包都是20w+的代码量。

有同学看见代码行数少,开始窃喜,其实少不见得是好事,很有可能还是坏事。

因为一旦深入就会发现,框架里大量的使用了Java 8的「函数编程特性」来编码,代码是精简了,但是读起来会有点费劲。

3.3 源码分析方法

有很多同学,一看到代码就兴奋,恨不得一下就能读完,然而实际上,这样的做法并不可取。

我们真的需要读完所有源码吗?实际上,没有必要,需要什么看什么,缺什么找什么。

带着目的去读,不断结合实践去读,才能更有效的分析源码。

源码分析的捷径就是没有捷径。

我常用的笨办法就是,多问自己几个问题,再看源码。比如:

  • 为什么现在大厂都喜欢用流控降级?什么时候不适用?
  • 这个开源框架用了什么设计模式?底层原理又是那些?能带给我们哪些启示?
  • 为什么作者使用了函数编程特性?有什么技巧可以借鉴?
  • 框架用到了哪些数据结构和算法?
  • 如果是我来设计流控降级系统该怎么设计?有哪些关键点要注意?
  • 轻量级一定好吗?解决了哪些问题?又带来了哪些问题?

有时问题不见得都能得到解决,但是这个思考的过程却很珍贵,而写下对源码的分析也是对这种思考的一种记录。

4.小结

文章简要介绍了 Resilience4j 框架,并完成了调试环境的搭建,在运行过程中遇见了一个小问题,并着手解决。然后,从代码模块结构入手,做好源码分析的前期准备工作。

5.参考文档

  • https://github.com/resilience4j/resilience4j
  • https://resilience4j.readme.io/docs
  • https://stackoverflow.com/questions/38056899/jmh-unable-to-find-the-resource-meta-inf-benchmarklist
  • https://github.com/melix/jmh-gradle-plugin
  • https://www.jianshu.com/p/175f746be1b4
  • https://github.com/artyushov/idea-jmh-plugin/issues/13

这篇关于Resilience4j 源码解析(1):简介及调试环境搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/274384

相关文章

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码