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

发布时间:2020-09-08 00:28:40

来源:脚本之家

阅读:99

作者:achuo

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:

processor="itemProcesser" commit-interval="1" />

processor="itemProcesser" commit-interval="1" />

processor="itemProcesser" commit-interval="1" />

整个 job 的执行是存储在数据库中的,所以即使是某一个step出错失败,也不需要全部从头开始执行这个job.下面是一个真正的入门教程例子.

采用 jar包如下:

spring-batch-2.2.3 以上版本,但是我在2.2.3版本中发现 org/springframework/batch/core/schema-mysql.sql 里面的的mysql 创建表的语句是有问题的,也就是少了“," 号导致的问题( NOT NULL, 后面几个创建表的语句NOT NULL 后面少了逗号),当然你可以自己修改后再执行,执行完毕后有如下几个表:

xstream-1.3.jar 必须的。

jettison-1.3.3.jar也是必须的, 否则会出现

java.lang.NoClassDefFoundError: org/codehaus/jettison/mapped/MappedXMLOutputFactory错误。

另外我用的spring 是 3.1 版本的,可以下载相关jar包,还有apache common 相关jar包就可以了。

mysql-connect-java-5.1.jar 连接mysql  数据库用的。

假设要将如下 csv 文件读取出来处理之后,写入到一个xml文件之中.

,"213,100",980,"mkyong", 29/7/2013

,"320,200",1080,"staff 1", 30/7/2013

,"342,197",1200,"staff 2", 31/7/2013

用 FlatFileItemReader 去读取CSV 文件, 用 itemProcessor 去处理数据,用 StaxEventItemWriter 去写数据

job 的定义如下(job-hello-world.xml):

xmlns:batch="http://www.springframework.org/schema/batch" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/batch

http://www.springframework.org/schema/batch/spring-batch-2.2.xsd

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.1.xsd

">

commit-interval="10">

class="org.springframework.batch.item.file.transform.DelimitedLineTokenizer">

yihaomen.model.Report

映射csv文件到 Report 对象并写XML文件 (通过 jaxb annotations).

package yihaomen.model;

import java.math.BigDecimal;

import java.util.Date;

import javax.xml.bind.annotation.XmlAttribute;

import javax.xml.bind.annotation.XmlElement;

import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement(name = "record")

public class Report {

private int id;

private BigDecimal sales;

private int qty;

private String staffName;

private Date date;

@XmlAttribute(name = "id")

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

@XmlElement(name = "sales")

public BigDecimal getSales() {

return sales;

}

public void setSales(BigDecimal sales) {

this.sales = sales;

}

@XmlElement(name = "qty")

public int getQty() {

return qty;

}

public void setQty(int qty) {

this.qty = qty;

}

@XmlElement(name = "staffName")

public String getStaffName() {

return staffName;

}

public void setStaffName(String staffName) {

this.staffName = staffName;

}

public Date getDate() {

return date;

}

public void setDate(Date date) {

this.date = date;

}

@Override

public String toString() {

return "Report [id=" + id + ", sales=" + sales + ", qty=" + qty + ", staffName=" + staffName + "]";

}

}

为了转换日期,用了自定义的 FieldSetMapper. 如果没有数据需要转换, BeanWrapperFieldSetMapper 通过名称name 去自动映射值。

package yihaomen;

import java.text.ParseException;

import java.text.SimpleDateFormat;

import org.springframework.batch.item.file.mapping.FieldSetMapper;

import org.springframework.batch.item.file.transform.FieldSet;

import org.springframework.validation.BindException;

import yihaomen.model.Report;

public class ReportFieldSetMapper implements FieldSetMapper {

private SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");

@Override

public Report mapFieldSet(FieldSet fieldSet) throws BindException {

Report report = new Report();

report.setId(fieldSet.readInt(0));

report.setSales(fieldSet.readBigDecimal(1));

report.setQty(fieldSet.readInt(2));

report.setStaffName(fieldSet.readString(3));

//default format yyyy-MM-dd

//fieldSet.readDate(4);

String date = fieldSet.readString(4);

try {

report.setDate(dateFormat.parse(date));

} catch (ParseException e) {

e.printStackTrace();

}

return report;

}

}

在写入数据之前调用itemProcessor 处理数据

package yihaomen;

import org.springframework.batch.item.ItemProcessor;

import yihaomen.model.Report;

public class CustomItemProcessor implements ItemProcessor {

@Override

public Report process(Report item) throws Exception {

System.out.println("Processing..." + item);

return item;

}

}

spring 配置文件和数据库配置文件

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">

class="org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">

class="org.springframework.batch.support.transaction.ResourcelessTransactionManager" />

class="org.springframework.batch.core.launch.support.SimpleJobLauncher">

xmlns:jdbc="http://www.springframework.org/schema/jdbc"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.2.xsd

http://www.springframework.org/schema/jdbc

http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd">

class="org.springframework.jdbc.datasource.DriverManagerDataSource">

class="org.springframework.batch.support.transaction.ResourcelessTransactionManager" />

运行程序

package yihaomen;

import org.springframework.batch.core.Job;

import org.springframework.batch.core.JobExecution;

import org.springframework.batch.core.JobParameters;

import org.springframework.batch.core.launch.JobLauncher;

import org.springframework.context.ApplicationContext;

import org.springframework.context.support.ClassPathXmlApplicationContext;

public class App {

public static void main(String[] args) {

String[] springConfig =

{

"spring/batch/jobs/job-hello-world.xml"

};

ApplicationContext context =

new ClassPathXmlApplicationContext(springConfig);

JobLauncher jobLauncher = (JobLauncher) context.getBean("jobLauncher");

Job job = (Job) context.getBean("helloWorldJob");

try {

JobExecution execution = jobLauncher.run(job, new JobParameters());

System.out.println("Exit Status : " + execution.getStatus());

} catch (Exception e) {

e.printStackTrace();

}

System.out.println("Done");

}

}

运行结果 :

十二月 03, 2013 8:56:24 下午 org.springframework.batch.core.launch.support.SimpleJobLauncher$1 run

INFO: Job: [FlowJob: [name=helloWorldJob]] launched with the following parameters: [{}]

十二月 03, 2013 8:56:24 下午 org.springframework.batch.core.job.SimpleStepHandler handleStep

INFO: Executing step: [step1]

Processing...Report [id=1001, sales=213100, qty=980, staffName=yihaomen]

Processing...Report [id=1002, sales=320200, qty=1080, staffName=staff 1]

Processing...Report [id=1003, sales=342197, qty=1200, staffName=staff 2]

十二月 03, 2013 8:56:25 下午 org.springframework.batch.core.launch.support.SimpleJobLauncher$1 run

INFO: Job: [FlowJob: [name=helloWorldJob]] completed with the following parameters: [{}] and the following status: [COMPLETED]

Exit Status : COMPLETED

Done

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

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

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

java中batch基础_详解Spring batch 入门学习教程(附源码)相关推荐

  1. java batch基础_详解Spring Batch 轻量级批处理框架实践

    实践内容 从 MariaDB 一张表内读 10 万条记录,经处理后写到 MongoDB . 具体实现 1.新建 Spring Boot 应用,依赖如下: org.springframework.boo ...

  2. java按钮权限控制_详解Spring Security 中的四种权限控制方式

    Spring Security 中对于权限控制默认已经提供了很多了,但是,一个优秀的框架必须具备良好的扩展性,恰好,Spring Security 的扩展性就非常棒,我们既可以使用 Spring Se ...

  3. java中parent结构_详解java中继承关系类加载顺序问题

    详解java中继承关系类加载顺序问题 实例代码: /** * Created by fei on 2017/5/31. */ public class SonClass extends ParentC ...

  4. java中this.getclass()_详解java中this.getClass()和super.getClass()的实例

    详解java中this.getClass()和super.getClass()的实例 前言: 遇到this.getClass()和super.getClass()的返回值感到疑惑,经过探索豁然开朗. ...

  5. 【竞赛项目详解】二手车交易价格预测(附源码)

    文章目录 1 项目简介 2 项目分析 2.1 数据分析(EDA) 2.2 难点分析 2.3 可行性方案分析 3 方案设计 3.1 特征工程 3.2 模型构建与训练 4 结果分析 5 源码链接 1 项目 ...

  6. java springmvc权限校验_详解Spring MVC使用Filter实现登录及权限验证判断

    登录和权限验证判断在后台管理系统中是最常用的功能,这部分代码是比较固定和独立的,为了减少对业务代码入侵性,一般我会考虑使用Filter来实现,下面我就来详细说一下我的实现思路和代码: 前台页面: St ...

  7. 【PHP】一文详解如何连接Mysql数据库(附源码)

  8. java中的进制输出转换_Java I/O : Java中的进制详解

    作者:李强强 上一篇,泥瓦匠基础地讲了下Java I/O : Bit Operation 位运算.这一讲,泥瓦匠带你走进Java中的进制详解. 一.引子 在Java世界里,99%的工作都是处理这高层. ...

  9. Java中的static关键字详解

    ** Java中的static关键字详解 ** 在一个类中定义一个方法为static,即静态的,那就是说无需本类的对象就可以调用此方法.调用一个静态方法就是 "类名.方法名" ,静 ...

最新文章

  1. T-SQL编程基础-基本语法
  2. 使用plsql创建定时任务并执行
  3. 开发辅助 | 阿里图标库iconfont入门使用
  4. 【Flask】Flask常用信号
  5. [WCF]NetTcpBinding在IIS中使用的详细配置方法
  6. 设计灵感|展览海报如何编排?
  7. aes解密算法 java_AES算法实现Java和JS互通加解密
  8. 使用Mac电脑内置的屏幕共享功能,进行远程桌面管理
  9. URLClassLoader使用方法及事例程序
  10. 2018最新JAVA基础面试题和高级面试题
  11. 内网穿透干货教程,1分钟极速穿透内网端口
  12. 开拓者队医当选年度最佳 球迷:罗伊情何以堪
  13. python with打开多个文件_在python中使用with打开多个文件的方法
  14. OpenLayers分屏联动对比
  15. 时间序列模型SCINet(代码解析)
  16. linux quota硬盘,Linux系统中quota磁盘命令的相关使用解析
  17. PCIe扫盲——热插拔简要介绍
  18. 大唐西域记 唐朝时代的世界划分 Re: [转载]悟空的仕途生涯(长)
  19. 中国移动电商APP用户活跃度
  20. 基于c51单片机的毕业设计——智能温度控制

热门文章

  1. Linq初级班 Linq To XML体验(基础篇)
  2. Samba服务器的安装与配置
  3. 二叉树--先序中序遍历求后序遍历
  4. Delphi XE2 发布了,期待了很久的东西,开始学习中。
  5. 以太网控制芯片DM9000在2440裸机上终于能正确接收数据了(源代码工程已经上传)...
  6. ORA-01113 file 1 needs media recovery
  7. 如何设置Java Spring Boot JWT授权和认证
  8. ios uiview 如何刷新_UIView的重绘及布局刷新
  9. 如何高效学习java课程
  10. 学java为什么要报java培训班?