本文主要是介绍soul学习初识divide插件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
先梳理下经过divide插件的大致执行流程
- 直接看bootstrap日志
猜测 :AbstractSoulPlugin,WebClientPlugin 是入口,
public abstract class AbstractSoulPlugin implements SoulPlugin
public class WebClientPlugin implements SoulPlugin
他们的顶层接口是 SoulPlugin
- 如日志日志可以看出两个插件的顺序
- 将断点加入到两个plugin的execute 方法
- 查看调用栈(就如图两处,其余都内部调用)
- 看了下代码具体细节没太懂,根据参数以及代码猜测是根据启插件的开启状态丢到不同的插件处理类里面(需要补充下webflux相关知识)
- 看到这里知道了主要头尾经过那些类,可以直接根据找我们今天要看的主题divide插件的处理实现过程
- DividePlugin#doExecute()方法
- 直接上断点先看看里面都操作了啥
大致debug一边意思是把请求丢进插件链里面对开启状态的插件挨个处理
- 在这里看到了soul-admin里面的plugins,selector,rule 以及相关conditions 数据
- 数据如何同步过来后续深入了解soul的几种同步数据的方式 todo
- 具体每个插件对应的对请求的处理代码如下 也就是chain.execute()方法
@Overridepublic Mono<Void> execute(final ServerWebExchange exchange) {return Mono.defer(() -> {if (this.index < plugins.size()) {SoulPlugin plugin = plugins.get(this.index++);Boolean skip = plugin.skip(exchange);if (skip) {return this.execute(exchange);}return plugin.execute(exchange, this);}return Mono.empty();});}
- 继续向下针对divide 插件的的请求体处理是 WebClientPlugin 进行处理也正是我们文章开始日志后面输出的类
- 如何处理请求body以及发送,响应过程 后面继续分析
总结
- 目标熟悉divide插件在网关中的大致执行流程
- 先从网关日志着手看头尾两部分断点先走一波
- 从类名方法名大致猜测每个类以及方法的作用
- 断点印证猜测
- 从代码结构看到了很多设计设计模式的具体应用,责任链模式,模板方法,等。后续在自己的代码中多尝试。
这篇关于soul学习初识divide插件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!