采集数据的任务-责任链的执行
在上一章中讲到了数据采集的处理器执行过程,在此过程中涉及到了 采集、计算、保存、升级维度 四个过程,使用责任链模式串联了起来执行
本章会详细讲解责任链的具体执行过程
数据采集的处理器
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的问题提问,而不仅仅只限于项目
- 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
- 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
- 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
- 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
- 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
