Getting Started with Spring Batch
INTRODUCING SPRING BATCH
Michael Hoffman
DEVELOPER AND PLURALSIGHT AUTHOR
@mhi_inc github.com/michaelhoffmantech
What Is Batch Processing?
Input Data Job Output
Large amount of Runs periodically to Processed data is
structured data process input data written, often to a
Commonly file-based efficiently database or other job
What Are the Scenarios for Batch Processing?
Data Transformation System Integration
End of the month accounting Bulk import of external data
process
Bulk import of data between
Daily retail order process internal systems
Hourly log of transactions Bulk export of data
What Is Stream Processing?
Input Data Job Output
Individual data change Runs near-real-time to Processed data is
events process incoming written, often to a
messages database or queue
Batch Data Processing
Benefits Challenges
Successfully handle high volumes of data Finite input data set
Can stop and re-start job at any time Can impact real-time processing
Mature approach Overkill for simpler computations
Other Reference
Martin Kleppmann: Designing Data-Intensive Applications: The Big
Ideas Behind Reliable, Scalable and Maintainable Systems. O’Reilly,
2017. ISBN-13: 978-1449373320.
Spring Batch Vitals
Released in 2008
Takes advantage of the Spring Framework
Currently version is 4.0
Spring Batch Benefits
Spring-based Java-based
Open source Support for batch features
Job
Step
Reader
Processor
Writer
What Will You Learn from This Course?
Configure a Spring Batch job
Implement a Spring Batch job
Implement reading, processing, and writing
data for a Spring Batch job
Implement unit tests for a Spring Batch job
Outside of the Course Scope
Spring and Java
Advanced batch concepts
Who Is This Course For?
Developers Architects
History of batch processing
Summary Basic definition of batch processing
Batch usage scenarios
Basic definition of stream processing
Benefits and challenges of batch
processing
Spring Batch