详解Spring batch 入门学习教程(附源码)

时间:2021-05-19

Spring batch 是一个开源的批处理框架.执行一系列的任务. 在 spring batch 中 一个job 是由许多 step 组成的。而每一个 step 又是由 READ-PROCESS-WRITE task或者 单个 task 组成。

1. "READ-PROCESS-WRITE" 处理,根据字面意思理解就可以:

  • READ 就是从资源文件里面读取数据,比如从xml文件,csv文件,数据库中读取数据.
  • PROCESS 就是处理读取的数据
  • WRITE 就是将处理过的数据写入到其他资源文件中去,可以是XML,CSV,或者数据库.
  • 比如:从CSV文件中 读取数据,经过处理之后,保存到数据库. spring batch 提供了很多类去处理这方面的东西。

    2.单个task, 也就是处理单个任务。比如在一个step 开始之前或者完成之后清除资源文件等.

    3.许多个step 组成在一起,就组成了一个job. 所以他们之间的关系,就如同下面的描述:

    一个 job = 很多steps
    一个step = 一个READ-PROCESS-WRITE 或者 一个task.
    同样一个job = step1 -->step2--step3 这样链表形式的组成.

    Spring batch 例子

    考虑如下一个批处理的例子,看起来有点啰嗦,只是为了说明用途:

    1. step1 : 从 A 文件夹中读取csv 文件,处理之后,写入到B文件夹中(READ-PROCESS-WRITE)
    2. step2 : 从 B 文件夹中读取CSV文件 ,处理之后, 存储到数据库中(READ-PROCESS-WRITE).
    3. step3 : 删除B文件夹下的CSV文件。(用到单个task)
    4. step4 : 从数据库读取数据,处理之后,生成XML报表文件(READ-PROCESS-WRITE).
    5. step5 : 读取XML报表,并发送EMAIL给管理员(用到单个task)

    用spring batch 我们可以如下定义这个job:

    <job id="abcJob" xmlns="http://PLETEDDone

    结果生成了output.xml 在你工程目录的 xml 目录下。

    整个源代码,除去jar包之后下载:Spring batch 入门教程下载

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章