Transaction Service Specification
Total Page:16
File Type:pdf, Size:1020Kb
Transaction Service Specification September 2002 Version 1.3 formal/02-08-07 An Adopted Specification of the Object Management Group, Inc. Copyright © 1997 BEA Systems Copyright © 1994, 1995, 1996 Groupe Bull Copyright © 1994, 1995, 1996 IBM Copyright © 1994, 1995, 1996 ICL plc Copyright © 1994, 1995, 1996 Iona Technologies Ltd. Copyright © 1994, 1995, 1996 Novell, Inc. Copyright © 2001, Object Management Group, Inc. Copyright © 1995, 1996 Sun Microsystems, Inc. Copyright © 1994, 1995, 1996 SunSoft, Inc. Copyright © 1994, 1995, 1996 Tandem Computers, Inc. Copyright © 1994, 1995, 1996 Tivoli Systems, Inc. Copyright © 1994, 1995, 1996 Transarc Corporation USE OF SPECIFICATION - TERMS, CONDITIONS & NOTICES The material in this document details an Object Management Group specification in accordance with the terms, conditions and notices set forth below. This document does not represent a commitment to implement any portion of this specification in any company's products. The information contained in this document is subject to change without notice. LICENSES The companies listed above have granted to the Object Management Group, Inc. (OMG) a nonexclusive, royalty-free, paid up, worldwide license to copy and distribute this document and to modify this document and distribute copies of the modified version. Each of the copyright holders listed above has agreed that no person shall be deemed to have infringed the copyright in the included material of any such copyright holder by reason of having used the specification set forth herein or having conformed any computer software to the specification. Subject to all of the terms and conditions below, the owners of the copyright in this specification hereby grant you a fully-paid up, non-exclusive, nontransferable, perpetual, worldwide license (without the right to sublicense), to use this specification to create and distribute software and special purpose specifications that are based upon this specification, and to use, copy, and distribute this specification as provided under the Copyright Act; provided that: (1) both the copyright notice identified above and this permission notice appear on any copies of this specification; (2) the use of the specifications is for informational purposes and will not be copied or posted on any network computer or broadcast in any media and will not be otherwise resold or transferred for commercial purposes; and (3) no modifications are made to this specification. This limited permission automatically terminates without notice if you breach any of these terms or conditions. Upon termination, you will destroy immediately any copies of the specifications in your possession or control. PATENTS The attention of adopters is directed to the possibility that compliance with or adoption of OMG specifications may require use of an invention covered by patent rights. OMG shall not be responsible for identifying patents for which a license may be required by any OMG specification, or for conducting legal inquiries into the legal validity or scope of those patents that are brought to its attention. OMG specifications are prospective and advisory only. Prospective users are responsible for protecting themselves against liability for infringement of patents. GENERAL USE RESTRICTIONS Any unauthorized use of this specification may violate copyright laws, trademark laws, and communications regulations and statutes. This document contains information which is protected by copyright. All Rights Reserved. No part of this work covered by copyright herein may be reproduced or used in any form or by any means--graphic, electronic, or mechanical, including photocopying, recording, taping, or information storage and retrieval systems--without permission of the copyright owner. DISCLAIMER OF WARRANTY WHILE THIS PUBLICATION IS BELIEVED TO BE ACCURATE, IT IS PROVIDED "AS IS" AND MAY CONTAIN ERRORS OR MISPRINTS. THE OBJECT MANAGEMENT GROUP AND THE COMPANIES LISTED ABOVE MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS PUBLICATION, INCLUDING BUT NOT LIMITED TO ANY WARRANTY OF TITLE OR OWNERSHIP, IMPLIED WARRANTY OF MERCHANTABILITY OR WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE. IN NO EVENT SHALL THE OBJECT MANAGEMENT GROUP OR ANY OF THE COMPANIES LISTED ABOVE BE LIABLE FOR ERRORS CONTAINED HEREIN OR FOR DIRECT, INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL, RELIANCE OR COVER DAMAGES, INCLUDING LOSS OF PROFITS, REVENUE, DATA OR USE, INCURRED BY ANY USER OR ANY THIRD PARTY IN CONNECTION WITH THE FURNISHING, PERFORMANCE, OR USE OF THIS MATERIAL, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. The entire risk as to the quality and performance of software developed using this specification is borne by you. This disclaimer of warranty constitutes an essential part of the license granted to you to use this specification. RESTRICTED RIGHTS LEGEND Use, duplication or disclosure by the U.S. Government is subject to the restrictions set forth in subparagraph (c) (1) (ii) of The Rights in Technical Data and Computer Software Clause at DFARS 252.227-7013 or in subparagraph (c)(1) and (2) of the Commercial Computer Software - Restricted Rights clauses at 48 C.F.R. 52.227-19 or as specified in 48 C.F.R. 227-7202-2 of the DoD F.A.R. Supplement and its successors, or as specified in 48 C.F.R. 12.212 of the Federal Acquisition Regulations and its successors, as applicable. The specification copyright owners are as indicated above and may be contacted through the Object Management Group, 250 First Avenue, Needham, MA 02494, U.S.A. TRADEMARKS The OMG Object Management Group Logo®, CORBA®, CORBA Academy®, The Information Brokerage®, XMI® and IIOP® are registered trademarks of the Object Management Group. OMG™, Object Management Group™, CORBA logos™, OMG Interface Definition Language (IDL)™, The Architecture of Choice for a Changing World™, CORBAservices™, CORBAfacilities™, CORBAmed™, CORBAnet™, Integrate 2002™, Middleware That's Everywhere™, UML™, Unified Modeling Language™, The UML Cube logo™, MOF™, CWM™, The CWM Logo™, Model Driven Architecture™, Model Driven Architecture Logos™, MDA™, OMG Model Driven Architecture™, OMG MDA™ and the XMI Logo™ are trademarks of the Object Management Group. All other products or company names mentioned are used for identification purposes only, and may be trademarks of their respective owners. COMPLIANCE The copyright holders listed above acknowledge that the Object Management Group (acting itself or through its designees) is and shall at all times be the sole entity that may authorize developers, suppliers and sellers of computer software to use certification marks, trademarks or other special designations to indicate compliance with these materials. Software developed under the terms of this license may claim compliance or conformance with this specification if and only if the software compliance is of a nature fully matching the applicable compliance points as stated in the specification. Software developed only partially matching the applicable compliance points may claim only that the software was based on this specification, but may not claim compliance or conformance with this specification. In the event that testing suites are implemented or approved by Object Management Group, Inc., software developed using this specification may claim compliance or conformance with the specification only if the software satisfactorily completes the testing suites. ISSUE REPORTING All OMG specifications are subject to continuous review and improvement. As part of this process we encourage readers to report any ambiguities, inconsistencies, or inaccuracies they may find by completing the Issue Reporting Form listed on the main web page http://www.omg.org, under Documents & Specifications, Report a Bug/Issue. Contents Preface . v 1. Overview . 1-1 1.1 Introduction . 1-1 1.2 Service Description . 1-2 1.2.1 Overview of Transactions . 1-2 1.2.2 Transactional Applications . 1-3 1.2.3 Definitions . 1-3 1.2.4 Transaction Service Functionality . 1-6 1.2.5 Principles of Function, Design, and Performance 1-8 1.3 Service Architecture. 1-12 1.3.1 Typical Usage . 1-13 1.3.2 Transaction Context . 1-13 1.3.3 Context Management . 1-14 1.3.4 Datatypes . 1-14 1.3.5 Structures . 1-16 1.3.6 Exceptions . 1-16 2. Transaction Service Interfaces . 2-1 2.1 Introduction . 2-2 2.2 Current Interface . 2-2 2.2.1 begin. 2-3 2.2.2 commit . 2-3 2.2.3 rollback. 2-3 2.2.4 rollback_only . 2-4 2.2.5 get_status . 2-4 September 2002 Transaction Service, v1.3 i Contents 2.2.6 get_transaction_name . 2-4 2.2.7 set_timeout . 2-4 2.2.8 get_timeout. 2-5 2.2.9 get_control . 2-5 2.2.10 suspend. 2-5 2.2.11 resume . 2-5 2.3 TransactionFactory Interface . 2-5 2.3.1 create . 2-6 2.3.2 recreate . 2-6 2.4 Control Interface . 2-6 2.4.1 get_terminator . 2-7 2.4.2 get_coordinator. 2-7 2.5 Terminator Interface. 2-7 2.5.1 commit . 2-8 2.5.2 rollback. 2-8 2.6 Coordinator Interface . 2-8 2.6.1 get_status . 2-9 2.6.2 get_parent_status . 2-10 2.6.3 get_top_level_status . 2-10 2.6.4 is_same_transaction . 2-10 2.6.5 is_ancestor_transaction. 2-11 2.6.6 is_descendant_transaction . 2-11 2.6.7 is_related_transaction. 2-11 2.6.8 is_top_level_transaction . 2-11 2.6.9 hash_transaction . 2-11 2.6.10 hash_top_level_tran . 2-11 2.6.11 register_resource . 2-11 2.6.12 register_synchronization. 2-12 2.6.13 register_subtran_aware . 2-12 2.6.14 rollback_only . 2-13 2.6.15 get_transaction_name . 2-13 2.6.16 create_subtransaction . 2-13 2.6.17 get_txcontext . 2-13 2.7 Recovery Coordinator Interface . 2-13 2.7.1 replay_completion . 2-14 2.8 Resource Interface . 2-14 2.8.1 prepare . 2-14 2.8.2 rollback. 2-15 2.8.3 commit . 2-15 2.8.4 commit_one_phase . 2-16 ii Transaction Service, v1.3 September 2002 Contents 2.8.5 forget .