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

com.sleepycat.je.LockTimeoutException Maven / Gradle / Ivy

The newest version!
/*-
 * Copyright (C) 2002, 2018, Oracle and/or its affiliates. All rights reserved.
 *
 * This file was distributed by Oracle as part of a version of Oracle Berkeley
 * DB Java Edition made available at:
 *
 * http://www.oracle.com/technetwork/database/database-technologies/berkeleydb/downloads/index.html
 *
 * Please see the LICENSE file included in the top-level directory of the
 * appropriate version of Oracle Berkeley DB Java Edition for a copy of the
 * license and additional information.
 */

package com.sleepycat.je;

import com.sleepycat.je.txn.Locker;

/**
 * Thrown when multiple threads are competing for a lock and the lock timeout
 * interval is exceeded for the current operation. This is normally because
 * another transaction or cursor holds a lock for longer than the timeout
 * interval. It may also occur if the application fails to close a cursor, or
 * fails to commit or abort a transaction, since any locks held by the cursor
 * or transaction will be held indefinitely.
 *
 * 

This exception is not thrown if a deadlock is detected, even if the * timeout elapses before the deadlock is broken. If a deadlock is detected, * {@link DeadlockException} is always thrown instead.

* *

The lock timeout interval may be set using * {@link EnvironmentConfig#setLockTimeout} or * {@link Transaction#setLockTimeout}.

* *

The {@link Transaction} handle is invalidated as a result of this * exception.

* *

Normally, applications should catch the base class {@link * LockConflictException} rather than catching one of its subclasses. All lock * conflicts are typically handled in the same way, which is normally to abort * and retry the transaction. See {@link LockConflictException} for more * information.

* * @since 4.0 */ public class LockTimeoutException extends LockConflictException { private static final long serialVersionUID = 1; /** * For internal use only. * @hidden */ public LockTimeoutException(Locker locker, String message) { super(locker, message); } /** * For internal use only. * @hidden */ private LockTimeoutException(String message, LockTimeoutException cause) { super(message, cause); } /** * For internal use only. * @hidden */ @Override public OperationFailureException wrapSelf(String msg) { return new LockTimeoutException(msg, this); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy