All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.arjuna.ats.internal.txoj.recovery.RecoveredTransactionalObject Maven / Gradle / Ivy

There is a newer version: 4.17.43.Final
Show newest version
/*
 * JBoss, Home of Professional Open Source
 * Copyright 2006, Red Hat Middleware LLC, and individual contributors 
 * as indicated by the @author tags. 
 * See the copyright.txt in the distribution for a
 * full listing of individual contributors. 
 * This copyrighted material is made available to anyone wishing to use,
 * modify, copy, or redistribute it subject to the terms and conditions
 * of the GNU Lesser General Public License, v. 2.1.
 * This program is distributed in the hope that it will be useful, but WITHOUT A 
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A 
 * PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more details.
 * You should have received a copy of the GNU Lesser General Public License,
 * v.2.1 along with this distribution; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 
 * MA  02110-1301, USA.
 * 
 * (C) 2005-2006,
 * @author JBoss Inc.
 */
/*
 * Copyright (C) 2000, 2001,
 *
 * Hewlett-Packard Arjuna Labs,
 * Newcastle upon Tyne,
 * Tyne and Wear,
 * UK.
 *
 * $Id: RecoveredTransactionalObject.java 2342 2006-03-30 13:06:17Z  $
 */

package com.arjuna.ats.internal.txoj.recovery;

import com.arjuna.ats.arjuna.StateManager;
import com.arjuna.ats.arjuna.common.Uid;
import com.arjuna.ats.arjuna.coordinator.ActionStatus;
import com.arjuna.ats.arjuna.exceptions.ObjectStoreException;
import com.arjuna.ats.arjuna.objectstore.ParticipantStore;
import com.arjuna.ats.arjuna.recovery.TransactionStatusConnectionManager;
import com.arjuna.ats.arjuna.state.InputObjectState;
import com.arjuna.ats.internal.arjuna.Header;
import com.arjuna.ats.txoj.logging.txojLogger;

/**
 * TransactionalObject shell instantiated at recovery time.
 * 

* Instantiated only for TransactionalObjects that are found (by * {@link TORecoveryModule}) to be in an uncommitted (indeterminate) state. The * status of the transaction that created the uncommitted state is determined - * if the transaction rolled back, the original state of the TransactionalObject * is reinstated. If the transaction rolled back (or is still in progress), no * change is made - the completion (including completion in recovery) of the * transaction will be applied to the transactional object (eventually). *

* Instantiation from the ObjectStore ignores all of the TO except for the * information in the header ( see * {@link com.arjuna.ats.arjuna.StateManager#packHeader StateManager.packHeader} * ), which is overridden by this class). *

* * @author Peter Furniss ([email protected]), Mark Little * ([email protected]) * @version $Id: RecoveredTransactionalObject.java 2342 2006-03-30 13:06:17Z $ */ /* * Does not extend LockManager or StateManager because they are concerned with * activating the committed state, and this is only concerned with the * uncommitted. */ public class RecoveredTransactionalObject extends StateManager { protected RecoveredTransactionalObject(Uid objectUid, String originalType, ParticipantStore participantStore) { _ourUid = objectUid; _type = originalType; _participantStore = participantStore; _transactionStatusConnectionMgr = new TransactionStatusConnectionManager(); if (txojLogger.logger.isDebugEnabled()) { txojLogger.logger.debug("RecoveredTransactionalObject created for "+_ourUid); } } protected final void replayPhase2 () { if (findHoldingTransaction()) { /* * There is a transaction holding this in uncommitted state find out * what the Status is. We have no idea what type of transaction it * is, so leave that to the cache. */ if (txojLogger.logger.isDebugEnabled()) { txojLogger.logger.debug("TO held by transaction "+_owningTransactionUid); } int tranStatus = _transactionStatusConnectionMgr .getTransactionStatus(_owningTransactionUid); if (txojLogger.logger.isDebugEnabled()) { txojLogger.logger.debug("RecoveredTransactionalObject - transaction status "+ActionStatus.stringForm(tranStatus)); } boolean inactive = false; if (tranStatus == ActionStatus.INVALID) // should be // ActionStatus.NO_ACTION { if (txojLogger.logger.isDebugEnabled()) { txojLogger.logger.debug("transaction Status from original application "+Integer.toString(tranStatus)+" and inactive: "+inactive); } inactive = true; } /* * Only do anything if we are sure the transaction rolledback if it * is still in progress in the original application, let that run * otherwise the transaction should recover and do the committment * eventually. */ if ((tranStatus == ActionStatus.ABORTED) || inactive) { rollback(); } else commit(); } else { if (txojLogger.logger.isDebugEnabled()) { txojLogger.logger.debug("RecoveredTransactionalObject.replayPhase2 - cannot find/no holding transaction"); } } } /** * Determine which transaction got this into uncommitted state return true * if there is such a transaction */ private final boolean findHoldingTransaction () { InputObjectState uncommittedState = null; _originalProcessUid = new Uid(Uid.nullUid()); try { uncommittedState = _participantStore.read_uncommitted(_ourUid, _type); } catch (ObjectStoreException e) { txojLogger.i18NLogger.warn_recovery_RecoveredTransactionalObject_6(e); return false; // probably } /* * Get the transaction and original process information from the saved * state. */ _originalProcessUid = null; _owningTransactionUid = null; try { Header hdr = new Header(); unpackHeader(uncommittedState, hdr); _originalProcessUid = hdr.getProcessId(); _owningTransactionUid = hdr.getTxId(); if (txojLogger.logger.isDebugEnabled()) { txojLogger.logger.debug("RecoveredTransactionalObject::findHoldingTransaction - uid is "+_owningTransactionUid); } return _owningTransactionUid.notEquals(Uid.nullUid()); } catch (Exception e) { txojLogger.i18NLogger.warn_recovery_RecoveredTransactionalObject_8(e); } return false; } private final void rollback () { try { _participantStore.remove_uncommitted(_ourUid, _type); } catch (ObjectStoreException e) { txojLogger.i18NLogger.warn_recovery_RecoveredTransactionalObject_9(_ourUid, e); } } private final void commit () { try { _participantStore.commit_state(_ourUid, _type); } catch (ObjectStoreException e) { txojLogger.i18NLogger.warn_recovery_RecoveredTransactionalObject_10(_ourUid, e); } } private Uid _ourUid; private Uid _owningTransactionUid; private Uid _originalProcessUid; private ParticipantStore _participantStore; private String _type; private TransactionStatusConnectionManager _transactionStatusConnectionMgr; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy