Synopses & Reviews
Spring Batch (framework) is a family member of the very popular Spring Framework. It deals with batch processes and how to handle them in day-to-day complex enterprise Java application development that involves multiple batch processes, usually found in complex financial, banking and insurance calculations and transactions--the very type of stuff that put Spring on the map initially, and made it the success it is today among Java developers. Pro Spring Batch is intended to answer three questions:
What? What is batch processing? What does it entail? What makes it different from the other applications we are developing? What are the challenges inherent in the development of a batch process? Why? Why do batch processing? Why can't we just process things as we get them? Why do we do batch processing differently than the web applications that we currently work on? How? How to implement a robust, scalable, distributed batch processing system using open source frameworks. This book gives you concrete examples of how each piece of functionality is used and why you would use it in a real world application. This includes providing tips that the school of hard knocks has taught the author in his experience with Spring Batch. Examples like limiting transaction commit counts because of the overhead built into the framework to maintain state are things that are either missed completely in the documentation or are easily glossed over, but will be pointed out in this book.
The author also walks you through, from end to end, the design and implementation of a batch process based upon a real world example. This includes basic project setup, implementation, testing, tuning and scaling for large volumes. Moreover, Pro Spring Batch covers the integration of useful libraries such as ehCache with Spring Batch to expand the capabilities of the framework. What you'll learn What are the Batch concepts and how they relate to the Spring Batch framework How to conduct Declaritive I/O using the Spring Batch readers/writers What are the Data integrity techniques including transactions and job state/restartability How to do Scalability via distributed batch processing How to handle Testing batch processes (Unit and functional) and much more... Who this book is for
Java Developers with Spring experience. Java Architects designing batch solutions. More specifically, this book is intended for those who have a solid foundation in the core Java platform. Batch processing covers a wide spectrum of topics, not all of which are covered in detail in this book. Concepts in Java which the reader should be comfortable with include file I/O, JDBC, and transactions. Given that Spring Batch is a framework built upon the open source IoC Container Spring, which will not be covered in this book, it is expected that the reader will be familiar with it's concepts and conventions. With that in mind, the reader is not expected to have any prior exposure to the Spring Batch framework. All concepts related to it will be explained in detail with working examples.
Synopsis
- Batch and Spring
- Spring Batch 101
- Sample Job
- Understanding Jobs and Steps
- Job Repository and Metadata
- Running a Job
- Readers
- Item Processors
- Item Writers
- Sample Application
- Scaling and Tuning
- Testing Batch Processes
Synopsis
Since its release, Spring Framework has transformed virtually every aspect of Java development including web applications, security, aspect-oriented programming, persistence, and messaging. Spring Batch, one of its newer additions, now brings the same familiar Spring idioms to batch processing. Spring Batch addresses the needs of any batch process, from the complex calculations performed in the biggest financial institutions to simple data migrations that occur with many software development projects. Pro Spring Batch is intended to answer three questions: What? What is batch processing? What does it entail? What makes it different from the other applications we are developing? What are the challenges inherent in the development of a batch process? Why? Why do batch processing? Why can?t we just process things as we get them? Why do we do batch processing differently than the web applications that we currently work on? How? How to implement a robust, scalable, distributed batch processing system using open-source frameworks
Pro Spring Batch gives concrete examples of how each piece of functionality is used and why it would be used in a real-world application. This includes providing tips that the school of hard knocks has taught author Michael Minella during his experience with Spring Batch. Pro Spring Batch includes examples of I/O options that are not mentioned in the official user's guide, as well as performance tips on things like how to limit the impact of maintaining the state of your jobs. The author also walks you through, from end to end, the design and implementation of a batch process based upon a theoretical real-world example. This includes basic project setup, implementation, testing, tuning and scaling for large volumes. What you?ll learn Batch concepts and how they relate to the Spring Batch framework How to use declarative I/O using the Spring Batch readers/writers Data integrity techniques used by Spring Batch, including transactions and job state/restartability How to scale batch jobs via distributed batch processing How to handle testing batch processes (Unit and functional) Who this book is for
Java developers with Spring experience. Java Architects designing batch solutions Table of Contents Batch and Spring Spring Batch 101 Sample Job Understanding Jobs and Steps Job Repository and Metadata Running a Job Readers Item Processors Item Writers Sample Application Scaling and Tuning Testing Batch Processes