ebook img

Aspect Oriented Programming – Transaction Management PDF

29 Pages·2006·0.57 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Aspect Oriented Programming – Transaction Management

Aspect Oriented Programming – Transaction Management Presentation outline ● Transaction management: why? A simple banking system – Example ● Existing solutions – without AOP Enterprise JavaBeans (JTA) Transaction Support for the bankning example – the conventional solution ● Basic AOP transaction management An AOP solution for the banking example ● Improved AOP transaction management AOP desing patterns ● Conclusion     1 Aspect Oriented Programming – Transaction Management Presentation outline ● Transaction management: why? A simple banking system – Example ● Existing solutions – without AOP Enterprise JavaBeans (JTA) Transaction Support for the bankning example – the conventional solution ● Basic AOP transaction management An AOP solution for the banking example ● Improved AOP transaction management AOP desing patterns ● Conclusion     2 Aspect Oriented Programming – Transaction Management Transaction – ACID properties A transaction is a set of operations respecting the ACID properties. ACID stands for: Atomicity Consistency Isolation Durability The most important feature is atomicity: the transaction is committed only if all its updates complete successfully. Otherwise, it is rolled back.     3 Aspect Oriented Programming – Transaction Management A simple banking system structure Let's introduce the example of a simple banking system. nested transaction     4 Aspect Oriented Programming – Transaction Management Nested transaction The method transfer contains a nested transaction:    public static void transfer(Account from, Account to, float amount) throws InsufficientBalanceException { to.credit(amount); from.debit(amount); } Both credit and debit perform a database update.     5 Aspect Oriented Programming – Transaction Management Why are transactions important? Imagine we want to execute the following operations: public static void main(String[] args) throws Exception { Account account1 = new AccountJDBCImpl(1); Account account2 = new AccountJDBCImpl(2); account1.credit(300); account1.debit(200); InterAccountTransferSystem.transfer(account1, account2, 100); InterAccountTransferSystem.transfer(account1, account2, 100); } The last operation fails and the database is left in an inconsistent state.  Example 1     6 Aspect Oriented Programming – Transaction Management Presentation outline ● Transaction management: why? A simple banking system – Example ● Existing solutions – without AOP Enterprise JavaBeans (JTA) Transaction Support for the bankning example – the conventional solution ● Basic AOP transaction management An AOP solution for the banking example ● Improved AOP transaction management AOP desing patterns ● Conclusion     7 Aspect Oriented Programming – Transaction Management Existing transaction management solutions Several companies offer transaction management systems (try to type transaction management in Google). We are going to look closer at how transaction management is handled in the “Java world”. ● JDBC (Java DataBase Connectivity) ● J2EE and JTA (Java Transaction API)     8 Aspect Oriented Programming – Transaction Management EJB Server and Java Transaction API (JTA) Let's look at the structure of an EJB server: ● The EJB Components implement the program business logic. ● The EJB Container makes several services available to the Components. One of these services is transaction management.     9 Aspect Oriented Programming – Transaction Management JTA transactions JTA is able to perform transactions over several data sources at the same time. JTA manages all the low level details. A JTA transaction can be demarcated in two different ways: ● Programmatic demarcation: the transaction is hardcoded. This is not much different from a JDBC transaction. ● Declarative demarcation: an xml configuration file defines for each method (or class), what kind of transaction action has to be carried out. The EJB Component methods do not contain transaction code anymore.     10

Description:
Improved AOP transaction management . The philosophy behind EJB declarative transaction demarcation is very similar to the AOP's one. However
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.