ebook img

Open Multithreaded Transactions: A Transaction Model for Concurrent Object-Oriented Programming PDF

292 Pages·2003·10.712 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 Open Multithreaded Transactions: A Transaction Model for Concurrent Object-Oriented Programming

OOPPEENN MMUULLTTIITTHHRREEAADDEEDD TTRRAANNSSAACCTTIIOONNSS OOppeenn MMuullttiitthhrreeaaddeedd TTrraannssaaccttiioonnss AA TTrraannssaaccttiioonn MMooddeell ffoorr CCoonnccuurrrreenntt OObbjjeecctt--OOrriieenntteedd PPrrooggrraammmmiinngg bbyy JJöörrgg KKiieennzzllee MMccGGiillll UUnniivveerrssiittyy,, MMoonnttrreeaall,, CCaannaaddaa ,, •• SSpprriinnggeerr--SScciieennccee++BBuussiinneessss MMeeddiiaa,, BB..VV.. LLiibbrraarryy ooff CCoonnggrreessss CCaattaallooggiinngg--iinn--PPuubblliiccaattiioonn DDaattaa IISSBBNN 997788--9900--448811--66447744--55 IISSBBNN 997788--9944--001177--00110033--77 ((eeBBooookk)) DDOOII 1100..11000077//997788--9944--001177--00110033--77 PPrriinntteedd oonn aacciidd--ffrreeee ppaappeerr AAllll RRiigghhttss RReesseerrvveedd ©© 22000033 SSpprriinnggeerr SScciieennccee++BBuussiinneessss MMeeddiiaa DDoorrddrreecchhtt OOrriiggiinnaallllyy ppuubblliisshheedd bbyy KKlluuwweerr AAccaaddeemmiicc PPuubblliisshheerrss iinn 22000033.. SSooffttccoovveerr rreepprriinntt oofftthhee hhaarrddccoovveerr 11sstt eeddiittiioonn 11997733 NNoo ppaarrtt ooff tthhiiss wwoorrkk mmaayy bbee rreepprroodduucceedd,, ssttoorreedd iinn aa rreettrriieevvaall ssyysstteemm,, oorr ttrraannssmmiitttteedd iinn aannyy ffoorrmm oorr bbyy aannyy mmeeaannss,, eelleeccttrroonniicc,, mmeecchhaanniiccaall,, pphhoottooccooppyyiinngg,, mmiiccrrooffiillmmiinngg,, rreeccoorrddiinngg oorr ootthheerrwwiissee,, wwiitthhoouutt wwrriitttteenn ppeerrmmiissssiioonn ffrroomm tthhee PPuubblliisshheerr,, wwiitthh tthhee eexxcceeppttiioonn ooff aannyy mmaatteerriiaall ssuupppplliieedd ssppeecciiffiiccaallllyy ffoorr tthhee ppuurrppoossee ooff bbeeiinngg eenntteerreedd aanndd eexxeeccuutteedd oonn aa ccoommppuutteerr ssyysstteemm,, ffoorr eexxcclluussiivvee uussee bbyy tthhee ppuurrcchhaasseerr ooff tthhee wwoorrkk.. ttoo VVaalleerriiee,, mmyy bbeesstt ffrriieenndd,, aanndd ttoo JJuulliiee,, LLaauurraa,, aanndd IIssaabbeellllee,,JJoorr tthheeiirr ssmmiilleess TTaabbllee ooff CCoonntteennttss FFoorreewwoorrdd ...................................................................................................... xxvviiii PPrreeffaaccee .......................................................................................................... xxiixx PPaarrtt II:: TTrraannssaaccttiioonn MMooddeellss FFuunnddaammeennttaall CCoonncceeppttss ................................................................................ 33 11..11 OObbjjeecctt--OOrriieennttaattiioonn .............................................................................. 33 11 ..11..11 BBaassee PPrriinncciipplleess .......................................................................... 33 11 ..ll..22 CCoonncceeppttss.................................................................................... 44 11..11..33 OObbjjeecctt--OOrriieenntteedd PPrrooggrraammmmiinngg .................................................. 55 11..11..44 EEvvoolluuttiioonn ooffOObbjjeecctt--OOrriieenntteedd PPrrooggrraammmmiinngg .............................. 66 11..11..55 OObbjjeeccttss ........................................................................................ 77 11 ..11..66 CCllaasssseess ........................................................................................ 77 11..11..77 IInnhheerriittaannccee .................................................................................. 77 11..11..88 PPoollyymmoorrpphhiissmm ............................................................................ 88 11 ..11..99 IInntteerraaccttiioonnss ................................................................................ 88 11 ..11..1100 PPrreeccoonnddiittiioonnss,, PPoosstteeoonnddiittiioonnss aanndd IInnvvaarriiaannttss ............................ 99 11..22 AAssppeecctt--OOrriieennttaattiioonn .............................................................................. 99 11..33 CCoonnccuurrrreennccyy ...................................................................................... 1111 11..33..ll NNaattuurree ooff CCoonnccuurrrreenntt SSyysstteemmss .................................................. 1111 11..33..22 CCoonnccuurrrreennccyy aanndd OObbjjeecctt--OOrriieenntteedd PPrrooggrraammmmiinngg .................... 1122 11 ..33..33 DDiirreecctt CCoommmmuunniiccaattiioonn ............................................................ 1133 11..33..44 CCoommmmuunniiccaattiioonn vviiaa SShhaarreedd PPaassssiivvee OObbjjeeccttss ............................ 1144 11..33..55 DDeeaaddlloocckkss aanndd SSttaarrvvaattiioonn ........................................................ 1155 11..44 FFaauulltt TToolleerraannccee .................................................................................. 1166 11..44..ll TTeerrmmiinnoollooggyy ............................................................................ 1166 11..44..22 FFaauulltt CCllaassssiiffiiccaattiioonn .................................................................. 1177 11..44..33 FFaaiilluurree SSeemmaannttiieess .................................................................... 1188 VVllll viii Open Multithreaded Transactions 1.4.4 Redundancy ....................................... 19 1.4.5 Error Processing ................................... 19 1.4.6 System Structuring for Fault Tolerance .................. 20 1.5 Exceptions ............................................. 21 1.5.1 Exception Handling in Concurrent Systems .............. 23 1.6 Persistence ............................................ 24 1.6.1 Persistence and Programming Languages ................ 25 2 Transaction Models ......................................... 27 2.1 Atomic Units of System Structuring ......................... 28 2.1.1 Atomic Units and Exception Handling .................. 28 2.1.2 Competitive and Cooperative Structuring Units ........... 29 2.2 Competitive World: Transactions and Derivatives .............. 29 2.2.1 Flat Transactions ................................... 31 2.2.2 Flat Transactions with Savepoints ...................... 32 2.2.3 Chained Transactions ............................... 34 2.2.4 Nested Transactions ................................. 34 2.2.5 Recoverable Communicating Actions ................... 39 2.2.6 Sagas ............................................ 39 2.3 OASIS Business Transactions ............................ .40 2.4 Collaborative World: Conversations and Derivatives .......... .41 2.4.1 Conversations .................................... .41 2.4.2 Atomic Actions .................................... 42 2.5 Combining Cooperative and Competitive Concurrency ......... .44 2.5.1 Multithreading inside Transactions .................... .44 2.5.2 Multithreaded Transactions .......................... .45 2.5.3 Coordinated Atomic Actions ......................... .47 3 Open Multithreaded Transactions .............................. 51 3.1 Motivations ............................................ 51 3.2 Requirements .......................................... 52 3.2.1 Integration Requirements ............................ 52 3.2.2 Guaranteeing the ACID Properties ..................... 53 3.3 Analysis of Existing Models ............................... 54 3.4 Open Multithreaded Transactions ........................... 55 3.4.1 Starting an Open Multithreaded Transaction .............. 56 3.4.2 Joining an Open Multithreaded Transaction .............. 56 3.4.3 Concurrency Control in Open Multithreaded Transactions .. 57 3.4.4 Ending an Open Multithreaded Transaction .............. 57 3.4.5 Exception Handing in Open Multithreaded Transactions .... 59 3.4.6 Classification of Exceptions .......................... 59 3.4.7 Internal Exceptions ................................. 59 3.4.8 External Exceptions ................................. 60 3.5 Additional Considerations ................................ 61 IX 3.5.1 Closing an Open Multithreaded Transaction .............. 61 3.5.2 Naming an Open Multithreaded Transaction ............. 62 3.5.3 Deserters ......................................... 63 3.5.4 Transactional Objects ............................... 63 3.5.5 Exception Resolution ................................ 64 3.5.6 Open Multithreaded Transactions as Firewalls for Errors .... 65 3.6 Comparison ............................................ 66 Part 11: The OPTIMA Framework 4 Overall Design ............................................. 71 4.1 General Considerations ................................... 71 4.2 Design Patterns ......................................... 72 4.2.1 The Abstract F actory Design Pattern ................... 72 4.2.2 The Strategy Design Pattern .......................... 74 4.2.3 The Serializer Design Pattern ......................... 75 4.3 OPTIMA Framework Design Overview ....................... 77 4.3.1 Transaction Support ................................. 78 4.3.2 Concurrency Control ................................ 78 4.3.3 Recovery ......................................... 79 5 Transaction Support ......................................... 81 5.1 States of an Open Multithreaded Transaction ................. 81 5.2 Synchronizing Participant Exit. ............................ 82 5.3 Monitoring Accesses to Transactional Objects ................ 82 5.4 Handling Nesting ....................................... 83 5.5 The Transaction Hierarchy ................................ 83 5.6 Handling Named Transactions ............................. 84 6 Concurrency Control ........................................ 85 6.1 Handling Cooperative Concurrency ......................... 86 6.2 Handling Competitive Concurrency ......................... 86 6.2.1 Pessimistic Concurrency Control ...................... 86 6.2.2 Optimistic Concurrency Control ....................... 88 6.2.3 Encapsulating Different Concurrency Control Strategies .... 89 6.3 Concurrency Control Information for Operations .............. 90 6.3.1 Strict Concurrency Control ........................... 91 6.3.2 Semantic-Based Concurrency Control .................. 91 6.3.3 Commutativity ..................................... 92 6.3.4 Encapsulating Operation Concurrency Control Information .. 94 7 Recovery .................................................. 97 7.1 Global Design .......................................... 98 7.2 Persistence Support ...................................... 98 x Open Multithreaded Transactions 7.2.1 Classification of Storage Devices ...................... 99 7.2.2 Object Serialization ................................ 103 7.2.3 Identification of Transactional Objects ................. 104 7.2.4 Storage Management ............................... 105 7.3 Caching Support ....................................... 106 7.3.1 Cache Fetch Algorithm ............................. 107 7.3.2 Cache Replacement Algorithm ....................... 107 7.3.3 Extensible Cache Design ............................ 108 7.3.4 Consequences of Caching ........................... 109 7.4 Logging .............................................. 109 7.4.1 Encapsulating Logging Techniques .................... 111 7.4.2 Encapsulating Log Information ....................... 111 7.5 Recovery Support ...................................... 112 7.5.1 Recovery Strategies ................................ 112 7.5.2 Encapsulating Recovery Strategies .................... 113 7.5.3 UndolNoRedo Recovery Algorithms .................. 115 7.5.4 NoUndolRedo Recovery Algorithms .................. 116 7.5.5 UndolRedo Recovery Algorithms ..................... 117 8 Interfacing with Programming Languages ....................... 119 8.1 Associating Participants with a Transaction .................. 120 8.2 Encapsulating Objects .................................. 121 8.2.1 The Transactional ObjecL ........................... 121 8.2.2 Handling Durability ................................ 123 8.2.3 Encapsulating Operation Invocations on Data Objects ..... 123 8.2.4 Tying Things Together ............................. 125 8.2.5 In-place Update and Deferred Update .................. 126 8.2.6 Trace of an Operation Invocation ..................... 128 8.3 Initializing and Shutting Down the Transaction Support ........ 129 8.4 Providing Transactions at the Programming Language Level .... 130 8.4.1 Procedural Interface ................................ 130 8.4.2 Object-Based Interface ............................. 133 8.4.3 Object-Oriented Interface ........................... 135 8.4.4 Aspect-Oriented Interface ........................... 136 8.4.5 Comments on a Potential Reflective Interface ........... 139 Part III: OPTIMA Implementation 9 Ada 95 ................................................ , .. 143 9.1 Ada 83 vs. Ada 95 ..................................... 143 9.2 Object-Oriented Programming in Ada ...................... 144 9.2.1 Controlled Types .................................. 146 xi 9.3 Concurrency in Ada .................................... 147 9.3.1 Tasks ........................................... 147 9.3.2 Task Identification ................................. 147 9.3.3 Task Attributes ................................... 148 9.3.4 The Rendezvous .................................. 148 9.3.5 Protected Types ................................... 149 9.3.6 Asynchronous Transfer of Contro1 .................... 152 9.4 Integration of Concurrency and Object-Orientation in Ada ...... 153 9.4.1 Extensible Protected Types .......................... 153 9.5 Distributed Systems in Ada .............................. 156 9.5.1 Remote Procedure Calls ............................ 157 9.5.2 Distributed Objects ................................ 159 9.5.3 Fault Tolerance in Distributed Ada .................... 159 9.6 Exceptions in Ada ...................................... 159 9.6.1 The Package Ada.Exceptions • • . . • . • • . • • 161 9.7 Persistence in Ada ...................................... 162 10 Implementation for Ada 95 ................................... 165 10.1 Implementing the Framework ............................. 165 10.1.1 Objects .......................................... 165 10.1.2 Concurrency Control ............................... 167 10.1.3 Persistence ....................................... 170 10.1.4 Initializing and Shutting Down the Transaction Support ... 173 10.2 Transaction Framework Interfaces for Ada 95 ................ 174 10.2.1 Transaction Identifier Management. ................... 174 10.2.2 Encapsulating Data Objects .......................... 175 10.2.3 Procedural Interface ................................ 176 10.2.4 Object-Based Interface ............................. 179 10.2.5 Object-Oriented Interface ........................... 182 10.2.6 Aspect-Oriented Interface ........................... 184 11 Related Work ............................................. 195 11.1 Argus ................................................ 195 11.2 Camelot and A val on .................................... 198 11.3 Arjuna ............................................... 201 11.4 Venari / ML .......................................... 203 11.5 Transactional Drago .................................... 204 11.6 PJama ............................................... 205 11.7 Isis .................................................. 206 11.8 CORBA Object Transaction Service ....................... 207 11 .9 Enterprise Java Beans ................................... 209 xii Open Multithreaded Transactions Part IV: Case Study 12 OnIine Auction System ...................................... 217 12.1 Requirements ......................................... 217 12.2 Application Design ..................................... 221 12.3 Implementation ........................................ 227 Bibliography ................................................ 241 Author and Citation Index ...................................... 263 Index ...................................................... 273

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.