diff --git a/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedLedgerImpl.java b/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedLedgerImpl.java index c22c8fb876028..67ce2ba4695aa 100644 --- a/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedLedgerImpl.java +++ b/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedLedgerImpl.java @@ -713,6 +713,9 @@ public void asyncAddEntry(ByteBuf buffer, int numberOfMessages, AddEntryCallback } private synchronized void internalAsyncAddEntry(OpAddEntry addOperation) { + if (!beforeAddEntry(addOperation)) { + return; + } pendingAddEntries.add(addOperation); final State state = STATE_UPDATER.get(this); if (state == State.Fenced) { @@ -775,10 +778,7 @@ private synchronized void internalAsyncAddEntry(OpAddEntry addOperation) { addOperation.setCloseWhenDone(true); STATE_UPDATER.set(this, State.ClosingLedger); } - // interceptor entry before add to bookie - if (beforeAddEntry(addOperation)) { - addOperation.initiate(); - } + addOperation.initiate(); } } @@ -1508,9 +1508,7 @@ public synchronized void updateLedgersIdsComplete(Stat stat) { ReferenceCountUtil.release(existsOp.data); } existsOp.setLedger(currentLedger); - if (beforeAddEntry(existsOp)) { - pendingAddEntries.add(existsOp); - } + pendingAddEntries.add(existsOp); } } while (existsOp != null && --pendingSize > 0);