亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為什么在 spring batch 中不調用拆分流?

為什么在 spring batch 中不調用拆分流?

白豬掌柜的 2023-05-24 15:31:57
我有以下工作配置:@Beanpublic Job job(Step databaseToDataBaseLowercaseSlaveStep) {    return jobBuilderFactory.get("myJob")            .incrementer(new RunIdIncrementer())            .flow(csvToDbLowercaseStep())            .next(databaseToDataBaseLowercaseSlaveStep)            .split(jobTaskExecutor())            .add(new FlowBuilder<Flow>("flow2")                    .start(notificationStep())                    .build()            )            .end()            .build();}預期的行動順序:執行csvToDbLowercaseStep并行運行 2 個步驟 a) databaseToDataBaseLowercaseSlaveStep b)notificationStep實際行動順序:執行csvToDbLowercaseStep執行databaseToDataBaseLowercaseSlaveStep所以notificationStep根本沒有被調用。為什么?我該如何糾正它?
查看完整描述

1 回答

?
陪伴而非守候

TA貢獻1757條經驗 獲得超8個贊

不支持向狀態鏈添加拆分,這是執行所需操作的正確方法(任務 1 同步后跟任務 2 和 3 并行):


    public Job job() {


        final Flow masterFlow = new FlowBuilder<Flow>("flow1").start(step("step1")).build();


        final Flow slaveFlow = new FlowBuilder<Flow>("flow2").split(new SimpleAsyncTaskExecutor())

                .add(

                        new FlowBuilder<Flow>("flow2.1").start(step("step2.1")).build(),

                        new FlowBuilder<Flow>("flow2.2").start(step("step2.2")).build())

                .build();


        return (jobBuilderFactory

                .get("job")

                .incrementer(new RunIdIncrementer())

                .start(masterFlow)

                .next(slaveFlow)

                .build())

                        .build();

    }


    private TaskletStep step(final String name) {


        return stepBuilderFactory.get(name)

                .tasklet((StepContribution contribution, ChunkContext chunkContext) -> {


                    System.out.println(name + " start");

                    Thread.sleep(1000);

                    System.out.println(name + " end");


                    return RepeatStatus.FINISHED;

                })

                .build();

    }

step1 開始


step1結束


step2.1開始


step2.2開始


step2.1結束


step2.2結束


希望這可以幫助。


更新


您的代碼試圖將拆分添加到狀態鏈中,并且根據 FlowBuilder.SplitBuilder 的文檔,它根本不受支持。


     * <em>Note:</em> Adding a split to a chain of states is not supported.  For example, the following configuration

     * is not supported.  Instead, the configuration would need to create a flow3 that was the split flow and assemble

     * them separately.

     *

     * <pre>

     * // instead of this

     * Flow complexFlow = new FlowBuilder&lt;SimpleFlow&gt;("ComplexParallelFlow")

     *                       .start(flow1)

     *                       .next(flow2)

     *                       .split(new SimpleAsyncTaskExecutor())

     *                       .add(flow3, flow4)

     *                       .build();

     *

     * // do this

     * Flow splitFlow = new FlowBuilder&lt;SimpleFlow&gt;("parallelFlow")

     *                       .start(flow3)

     *                       .split(new SimpleAsyncTaskExecutor())

     *                       .add(flow4).build();

     *

     * Flow complexFlow = new FlowBuilder&lt;SimpleFlow&gt;("ComplexParallelFlow")

     *                       .start(flow1)

     *                       .next(flow2)

     *                       .next(splitFlow)

     *                       .build();

     * </pre>


查看完整回答
反對 回復 2023-05-24
  • 1 回答
  • 0 關注
  • 144 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號