跳到主要内容

采集数据的任务-责任链的执行

在上一章中讲到了数据采集的处理器执行过程,在此过程中涉及到了 采集、计算、保存、升级维度 四个过程,使用责任链模式串联了起来执行

本章会详细讲解责任链的具体执行过程

数据采集的处理器

org.javaup.handler.core.data.impl.GatherDataHandler#dataHandle

public RuleHandleOutput dataHandle(TotalParamTransfers totalParamTransfers){
//使用责任链进行数据的处理,包括:采集、计算、保存、升级维度等
dataChainContext.getDataChainHandler().executeChain(totalParamTransfers);
return null;
}
  • 责任链执行GatherDataHandler.dataHandle:调用 DataChainContext 获取链头后,串行执行各节点。
  • 链构建DataChainContext.init:启动时收集所有链节点、按 order() 排序并串起来。
  • 节点职责由若干 AbstractDataChainHandler 子类各自实现,按顺序覆盖“采集/计算/保存/升级维度”。

接下来,我会按照 “入口 → 进入链 → 构建链 → 节点职责 → 逐步时序” 的顺序展开。

业务入口:规则处理与参数装配

public RuleHandleOutput handle(ParamTransfers paramTransfers){
//省略...
//数据处理器执行
return dataHandler.dataHandle(totalParamTransfers);
}

通过规则类型路由到具体 DataHandler(采集或查询)。

进入责任链:GatherDataHandler.dataHandle

@Override
public RuleHandleOutput dataHandle(TotalParamTransfers totalParamTransfers){
//使用责任链进行数据的处理,包括:采集、计算、保存、升级维度等
dataChainContext.getDataChainHandler().executeChain(totalParamTransfers);
return null;
}
  • 关键点
    • 这里不做业务处理,仅将装配好的 totalParamTransfers 交给链头,触发整条链依次执行。
    • 返回值在当前实现为 null,说明处理结果以“副作用”(如落库/发消息)为主。

链是如何被“串”起来的:DataChainContext

付费内容提示

该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放

加入星球后,你可以获得:

  • 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
  • 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
  • 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
  • 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠