栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

从Tasklet存储在JobExecutionContext中并在另一个Tasklet中访问

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

从Tasklet存储在JobExecutionContext中并在另一个Tasklet中访问

你至少有4种可能性:

  1. 使用ExecutionPromotionListener 将数据传递到以后的步骤
  2. 使用(spring)bean来保存步间数据,例如ConcurrentHashMap
    如果不采取进一步措施,该数据将无法重新启动
  3. 访问你的tasklet中的JobExecutionContext,应谨慎使用,这将导致并行步骤出现线程问题
  4. 使用新的jobscope(引入的弹簧批次3)
    从Tasklet访问JobExecution的代码示例:

设定值

public class ChangingJobExecutionContextTasklet implements Tasklet {        @Override    public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception {        // set variable in JobExecutionContext        chunkContext     .getStepContext()     .getStepExecution()     .getJobExecution()     .getExecutionContext()     .put("value", "foo");        // exit the step        return RepeatStatus.FINISHED;    }}

提取值

public class ReadingJobExecutionContextTasklet implements Tasklet {    private static final Logger LOG = LoggerFactory.getLogger(ChangingJobExecutionContextTasklet.class);        @Override    public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception {        // pull variable from JobExecutionContext        String value = (String) chunkContext   .getStepContext()   .getStepExecution()   .getJobExecution()   .getExecutionContext()   .get("value");        LOG.debug("Found value in JobExecutionContext:" + value);        // exit the step        return RepeatStatus.FINISHED;    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/402508.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号