X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatabroker%2FClientBackedTransactionChain.java;h=6ae7e51c54baea21c7a4315b6c90d1289f957902;hb=db3d7caeeb310f76a9a159f9a8d7e9beff89f645;hp=db30372676c43057749ae11d157901eaa77978d3;hpb=5a0edd493bafc365647bc6311b4b7da86a78645d;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/ClientBackedTransactionChain.java b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/ClientBackedTransactionChain.java index db30372676..6ae7e51c54 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/ClientBackedTransactionChain.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/main/java/org/opendaylight/controller/cluster/databroker/ClientBackedTransactionChain.java @@ -8,18 +8,20 @@ package org.opendaylight.controller.cluster.databroker; import com.google.common.base.Preconditions; +import java.util.ArrayList; +import java.util.List; import java.util.Map; import java.util.WeakHashMap; import javax.annotation.concurrent.GuardedBy; +import org.opendaylight.controller.cluster.access.concepts.TransactionIdentifier; import org.opendaylight.controller.cluster.databroker.actors.dds.AbstractClientHandle; import org.opendaylight.controller.cluster.databroker.actors.dds.ClientLocalHistory; import org.opendaylight.controller.cluster.databroker.actors.dds.ClientSnapshot; import org.opendaylight.controller.cluster.databroker.actors.dds.ClientTransaction; -import org.opendaylight.controller.md.sal.common.api.data.TransactionChainClosedException; -import org.opendaylight.controller.sal.core.spi.data.DOMStoreReadTransaction; -import org.opendaylight.controller.sal.core.spi.data.DOMStoreReadWriteTransaction; -import org.opendaylight.controller.sal.core.spi.data.DOMStoreTransactionChain; -import org.opendaylight.controller.sal.core.spi.data.DOMStoreWriteTransaction; +import org.opendaylight.mdsal.dom.spi.store.DOMStoreReadTransaction; +import org.opendaylight.mdsal.dom.spi.store.DOMStoreReadWriteTransaction; +import org.opendaylight.mdsal.dom.spi.store.DOMStoreTransactionChain; +import org.opendaylight.mdsal.dom.spi.store.DOMStoreWriteTransaction; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -35,34 +37,43 @@ final class ClientBackedTransactionChain implements DOMStoreTransactionChain { private final Map, Boolean> openSnapshots = new WeakHashMap<>(); private final ClientLocalHistory history; + private final boolean debugAllocation; - ClientBackedTransactionChain(final ClientLocalHistory history) { + ClientBackedTransactionChain(final ClientLocalHistory history, final boolean debugAllocation) { this.history = Preconditions.checkNotNull(history); + this.debugAllocation = debugAllocation; } @Override public DOMStoreReadTransaction newReadOnlyTransaction() { - return new ClientBackedReadTransaction(createSnapshot(), this); + return new ClientBackedReadTransaction(createSnapshot(), this, allocationContext()); } @Override public DOMStoreReadWriteTransaction newReadWriteTransaction() { - return new ClientBackedReadWriteTransaction(createTransaction()); + return new ClientBackedReadWriteTransaction(createTransaction(), allocationContext()); } @Override public DOMStoreWriteTransaction newWriteOnlyTransaction() { - return new ClientBackedWriteTransaction(createTransaction()); + return new ClientBackedWriteTransaction(createTransaction(), allocationContext()); } @Override public synchronized void close() { + final List abortedSnapshots = new ArrayList<>(); for (AbstractClientHandle snap : openSnapshots.keySet()) { - LOG.warn("Aborting unclosed transaction {}", snap.getIdentifier()); - snap.abort(); + final TransactionIdentifier id = snap.getIdentifier(); + LOG.debug("Aborting recorded transaction {}", id); + if (snap.abort()) { + abortedSnapshots.add(id); + } } openSnapshots.clear(); + if (!abortedSnapshots.isEmpty()) { + LOG.warn("Aborted unclosed transactions {}", abortedSnapshots, new Throwable("at")); + } history.close(); } @@ -71,19 +82,15 @@ final class ClientBackedTransactionChain implements DOMStoreTransactionChain { } private ClientSnapshot createSnapshot() { - try { - return recordSnapshot(history.takeSnapshot()); - } catch (org.opendaylight.mdsal.common.api.TransactionChainClosedException e) { - throw new TransactionChainClosedException("Transaction chain has been closed", e); - } + return recordSnapshot(history.takeSnapshot()); } private ClientTransaction createTransaction() { - try { - return recordSnapshot(history.createTransaction()); - } catch (org.opendaylight.mdsal.common.api.TransactionChainClosedException e) { - throw new TransactionChainClosedException("Transaction chain has been closed", e); - } + return recordSnapshot(history.createTransaction()); + } + + private Throwable allocationContext() { + return debugAllocation ? new Throwable("allocated at") : null; } private synchronized > T recordSnapshot(final T snapshot) {