J2EE除了提供了Servlet之外,還提供了大量的其它功能。Servlet開發者們也許難得使用這些功能,不情願也沒有時間用一個超出所需的大型J2EE服務器來替換自己的簡單的Servlet容器。然而,依據J2EE的模塊化特征,有可能將負責特定J2EE功能的小組件整合到Servlet容器裡,以此來增強WEB應用程序。其中之一就是事務。有關J2EE事務的完整描述,您可以參考Onjava上的其他三篇文章,現在只需知道事務是資源的操作步驟(例如:數據庫),它由四個屬性定義,這四個屬性根據其首字母濃縮為ACID:
原子性:事務的操作,或者是全部成功(此時提交事務),或者是全部不成功(此時回滾事務),謂之為all-or-nothing屬性。一個事務應該被視為單個工作單元,在一個事務裡面絕對不可能同時存在完成了的和沒有完成的操作。
一致性:完成了的事務將資源從一個有效狀態轉變為另一個有效狀態。一致性的具體例子有:數據庫的參照完整性和表中的主鍵唯一性。
獨立性在事務沒有提交之前,事務作用的共享資源的改變在事務之外是不可見的。獨立性確保了不同事務不會同時訪問正在更新的數據。
持久性:由事務提交的改變會永久存在。
JOTM(Java Open Transaction Manager)是由ObjectWeb協會開發的功能完整的且資源開放的獨立的事務管理器。它提供了JAVA應用程序的事務支持,而且與JTAJAVA事務API)兼容。您可以在JOTM home page了解到更多的詳細信息。在TOMCAT或其它Servlet容器整合了JOTM後,JSP和Servlet的開發者們就可以獲得事務的優勢輕而易舉的創建更多健壯的web應用程序。
為了突出事務是怎樣增強web應用程序的,舉一個常用的例子,web浏覽器與客戶端交互的ATM。
ATM 樣例:
情景
此例比較簡單:一個客戶想從 ATM 提款,輸入了他的客戶名稱,john_doe;想提款數,$50。如果他的銀行帳戶上有足夠的錢並且在 ATM 機上有足夠的現金的話,應用程序就能給他相當數目的現金,並從銀行帳戶上提出同樣的數目。否則,操作中斷,並且除出現錯誤信息之外,其他都不會改變。我們無需擔心安全問題,只是在猜想用戶是否正確授權。
這是一個非常簡單的例子,但是如果不使用事務,用別的方法執行起來將會很難。客戶端操作將會涉及到兩個不同的資源:ATM 和客戶銀行帳號。它們會自動的在應用程序設計中產生 ACID 問題。例如:如果在 ATM 上操作成功而在銀行帳戶上卻失敗也許是因為交流失敗),客戶將會取到錢,但是他的帳戶將不會更新。對於銀行來說,這就虧大了。更糟的是,如果銀行帳戶更新了,但是由於一個錯誤阻止 ATM 傳送錢,客戶得不到現金,但是帳戶上卻提掉了這筆款。
為了防止出現上述事故,在你的應用程序裡,你能夠 1) 聯系兩個資源,並告知兩者客戶執行的所有當前操作,2)詢問兩者是否能執行操作,3)如果兩者都同意,則請求操作。即使這樣,此方法也不能謂之足夠健壯,因為,如果客戶帳戶上的錢在第二步和第三步的時候被另外一操作提走,提款可能會失敗,例如,客戶帳戶不能出現逆差。
事務能使應用程序更簡單更健壯的之處就是:在同一事務的兩個資源上執行所有的操作的時候,它將會解決 ACID 的問題尤其是原子性)。