Book Image

Spring Essentials

Book Image

Spring Essentials

Overview of this book

Spring is an open source Java application development framework to build and deploy systems and applications that run on the JVM. It is the industry standard and the most popular framework among Java developers with over two-thirds of developers using it. Spring Essentials makes learning Spring so much quicker and easier with the help of illustrations and practical examples. Starting from the core concepts of features such as inversion of Control Container and BeanFactory, we move on to a detailed look at aspect-oriented programming. We cover the breadth and depth of Spring MVC, the WebSocket technology, Spring Data, and Spring Security with various authentication and authorization mechanisms. Packed with real-world examples, you’ll get an insight into utilizing the power of Spring Expression Language in your applications for higher maintainability. You’ll also develop full-duplex real-time communication channels using WebSocket and integrate Spring with web technologies such as JSF, Struts 2, and Tapestry. At the tail end, you will build a modern SPA using EmberJS at the front end and a Spring MVC-based API at the back end.By the end of the book, you will be able to develop your own dull-fledged applications with Spring.
Table of Contents (14 chapters)
Spring Essentials
Credits
About the Authors
About the Reviewer
www.PacktPub.com
Preface
Index

Spring Transaction support


Data-driven enterprise systems consider data integrity as paramount, hence transaction management is a critical feature supported by major databases and application servers. Spring framework provides comprehensive transaction support, abstracting any underlying infrastructure. Spring Transaction support includes a consistent approach across different transaction choices such as JTA, JPA, and JDO. It integrates well with all Spring data-access mechanisms. Spring Transaction supports both declarative and programmatic transaction management.

Note

A transaction can be defined as an atomic unit of data exchange, typically SQL statements in the case of relational databases, which should be either committed or rolled back as a block (all or nothing). A transactional system or a transaction management framework enforces ACID (Atomic, Consistent, Isolated, Durable) properties across the participating systems or resources (such as databases and messaging queues).