Return-Path: X-Original-To: apmail-geode-commits-archive@minotaur.apache.org Delivered-To: apmail-geode-commits-archive@minotaur.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id 8DA6C18379 for ; Wed, 21 Oct 2015 00:06:39 +0000 (UTC) Received: (qmail 63907 invoked by uid 500); 21 Oct 2015 00:06:39 -0000 Delivered-To: apmail-geode-commits-archive@geode.apache.org Received: (qmail 63873 invoked by uid 500); 21 Oct 2015 00:06:39 -0000 Mailing-List: contact commits-help@geode.incubator.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@geode.incubator.apache.org Delivered-To: mailing list commits@geode.incubator.apache.org Received: (qmail 63864 invoked by uid 99); 21 Oct 2015 00:06:39 -0000 Received: from Unknown (HELO spamd3-us-west.apache.org) (209.188.14.142) by apache.org (qpsmtpd/0.29) with ESMTP; Wed, 21 Oct 2015 00:06:39 +0000 Received: from localhost (localhost [127.0.0.1]) by spamd3-us-west.apache.org (ASF Mail Server at spamd3-us-west.apache.org) with ESMTP id 088AA180A4F for ; Wed, 21 Oct 2015 00:06:39 +0000 (UTC) X-Virus-Scanned: Debian amavisd-new at spamd3-us-west.apache.org X-Spam-Flag: NO X-Spam-Score: 1.77 X-Spam-Level: * X-Spam-Status: No, score=1.77 tagged_above=-999 required=6.31 tests=[KAM_ASCII_DIVIDERS=0.8, KAM_LAZY_DOMAIN_SECURITY=1, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, T_RP_MATCHES_RCVD=-0.01] autolearn=disabled Received: from mx1-us-east.apache.org ([10.40.0.8]) by localhost (spamd3-us-west.apache.org [10.40.0.10]) (amavisd-new, port 10024) with ESMTP id 1rYH_fUVmzP2 for ; Wed, 21 Oct 2015 00:06:37 +0000 (UTC) Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by mx1-us-east.apache.org (ASF Mail Server at mx1-us-east.apache.org) with SMTP id C8646439CB for ; Wed, 21 Oct 2015 00:06:36 +0000 (UTC) Received: (qmail 63836 invoked by uid 99); 21 Oct 2015 00:06:36 -0000 Received: from git1-us-west.apache.org (HELO git1-us-west.apache.org) (140.211.11.23) by apache.org (qpsmtpd/0.29) with ESMTP; Wed, 21 Oct 2015 00:06:36 +0000 Received: by git1-us-west.apache.org (ASF Mail Server at git1-us-west.apache.org, from userid 33) id 2F58CDFE2E; Wed, 21 Oct 2015 00:06:36 +0000 (UTC) Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: upthewaterspout@apache.org To: commits@geode.incubator.apache.org Message-Id: X-Mailer: ASF-Git Admin Mailer Subject: incubator-geode git commit: GEODE-244: Adding debug logging for testRecoverRedundancyParallelAsyncEventQueueSimulation Date: Wed, 21 Oct 2015 00:06:36 +0000 (UTC) Repository: incubator-geode Updated Branches: refs/heads/feature/GEODE-409 c2db92008 -> ef5d9e2d6 GEODE-244: Adding debug logging for testRecoverRedundancyParallelAsyncEventQueueSimulation This failure does not reproduce. I've enabled debug logging just for this one test case so that if it does fail again, I can track down what happened. Project: http://git-wip-us.apache.org/repos/asf/incubator-geode/repo Commit: http://git-wip-us.apache.org/repos/asf/incubator-geode/commit/ef5d9e2d Tree: http://git-wip-us.apache.org/repos/asf/incubator-geode/tree/ef5d9e2d Diff: http://git-wip-us.apache.org/repos/asf/incubator-geode/diff/ef5d9e2d Branch: refs/heads/feature/GEODE-409 Commit: ef5d9e2d6c5820b2faf20367b7f4172e77b96efa Parents: c2db920 Author: Dan Smith Authored: Tue Oct 20 16:24:06 2015 -0700 Committer: Dan Smith Committed: Tue Oct 20 17:06:09 2015 -0700 ---------------------------------------------------------------------- .../PartitionedRegionRebalanceOp.java | 52 ++++++++++++++------ .../control/RebalanceOperationDUnitTest.java | 29 +++++------ 2 files changed, 49 insertions(+), 32 deletions(-) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/incubator-geode/blob/ef5d9e2d/gemfire-core/src/main/java/com/gemstone/gemfire/internal/cache/partitioned/PartitionedRegionRebalanceOp.java ---------------------------------------------------------------------- diff --git a/gemfire-core/src/main/java/com/gemstone/gemfire/internal/cache/partitioned/PartitionedRegionRebalanceOp.java b/gemfire-core/src/main/java/com/gemstone/gemfire/internal/cache/partitioned/PartitionedRegionRebalanceOp.java index 39f4e97..46eb3df 100644 --- a/gemfire-core/src/main/java/com/gemstone/gemfire/internal/cache/partitioned/PartitionedRegionRebalanceOp.java +++ b/gemfire-core/src/main/java/com/gemstone/gemfire/internal/cache/partitioned/PartitionedRegionRebalanceOp.java @@ -77,6 +77,7 @@ public class PartitionedRegionRebalanceOp { private static final Logger logger = LogService.getLogger(); private static final int MAX_PARALLEL_OPERATIONS = Integer.getInteger("gemfire.MAX_PARALLEL_BUCKET_RECOVERIES", 8); + private final boolean DEBUG = Boolean.getBoolean("gemfire.LOG_REBALANCE"); private final boolean simulate; private final boolean replaceOfflineData; @@ -197,9 +198,7 @@ public class PartitionedRegionRebalanceOp { membershipChange = false; //refetch the partitioned region details after //a membership change. - if (logger.isDebugEnabled()) { - logger.debug("Rebalancing {} detected membership changes. Refetching details", leaderRegion); - } + debug("Rebalancing {} detected membership changes. Refetching details", leaderRegion); if(this.stats != null) { this.stats.incRebalanceMembershipChanges(1); } @@ -222,9 +221,7 @@ public class PartitionedRegionRebalanceOp { } } - if (logger.isDebugEnabled()) { - logger.debug("Rebalancing {} complete. Model:{}\n", leaderRegion, model); - } + debug("Rebalancing {} complete. Model:{}\n", leaderRegion, model); long end = System.nanoTime(); for(PartitionRebalanceDetailsImpl details : serialOperator.getDetailSet()) { @@ -444,22 +441,20 @@ public class PartitionedRegionRebalanceOp { int totalNumberOfBuckets = leaderRegion.getTotalNumberOfBuckets(); Set criticalMembers = resourceManager.getResourceAdvisor().adviseCritialMembers();; boolean removeOverRedundancy = true; + + debug("Building Model for rebalancing " + leaderRegion + + ". redundantCopies=" + redundantCopies + ", totalNumBuckets=" + + totalNumberOfBuckets + ", criticalMembers=" + criticalMembers + + ", simulate=" + simulate); + + model = new PartitionedRegionLoadModel(operator, redundantCopies, totalNumberOfBuckets, comparor, criticalMembers, leaderRegion); for (Map.Entry entry : detailsMap.entrySet()) { PartitionedRegion region = entry.getKey(); InternalPRInfo details = entry.getValue(); - if (isDebugEnabled) { - logger.debug("Added Region to model region={} details=", region); - } - for(PartitionMemberInfo memberDetails: details.getPartitionMemberInfo()) { - if (isDebugEnabled) { - logger.debug("Member: {} LOAD={}", memberDetails.getDistributedMember(), ((InternalPartitionDetails) memberDetails).getPRLoad()); - } - } - Set memberDetailSet = - details.getInternalPartitionDetails(); + OfflineMemberDetails offlineDetails; if(replaceOfflineData) { offlineDetails = OfflineMemberDetails.EMPTY_DETAILS; @@ -467,13 +462,38 @@ public class PartitionedRegionRebalanceOp { offlineDetails = details.getOfflineMembers(); } boolean enforceLocalMaxMemory = !region.isEntryEvictionPossible(); + + debug("Added Region to model region=" + region + ", offlineDetails=" + offlineDetails + + ", enforceLocalMaxMemory=" + enforceLocalMaxMemory); + + for(PartitionMemberInfo memberDetails: details.getPartitionMemberInfo()) { + debug( + "For Region: " + region + ", Member: " + memberDetails.getDistributedMember() + "LOAD=" + + ((InternalPartitionDetails) memberDetails).getPRLoad() + +", equivalentMembers=" + + dm.getMembersInSameZone((InternalDistributedMember) memberDetails.getDistributedMember())); + } + Set memberDetailSet = + details.getInternalPartitionDetails(); + model.addRegion(region.getFullPath(), memberDetailSet, offlineDetails, enforceLocalMaxMemory); } model.initialize(); + debug("Rebalancing {} starting. Model:\n{}", leaderRegion, model); + return model; } + private void debug(String message, Object ...params) { + if(logger.isDebugEnabled()) { + logger.debug(message, params); + } else if(logger.isInfoEnabled() && DEBUG) { + logger.info(message, params); + } + + } + /** * Create a redundant bucket on the target member * http://git-wip-us.apache.org/repos/asf/incubator-geode/blob/ef5d9e2d/gemfire-core/src/test/java/com/gemstone/gemfire/internal/cache/control/RebalanceOperationDUnitTest.java ---------------------------------------------------------------------- diff --git a/gemfire-core/src/test/java/com/gemstone/gemfire/internal/cache/control/RebalanceOperationDUnitTest.java b/gemfire-core/src/test/java/com/gemstone/gemfire/internal/cache/control/RebalanceOperationDUnitTest.java index 31d889c..e40222c 100644 --- a/gemfire-core/src/test/java/com/gemstone/gemfire/internal/cache/control/RebalanceOperationDUnitTest.java +++ b/gemfire-core/src/test/java/com/gemstone/gemfire/internal/cache/control/RebalanceOperationDUnitTest.java @@ -17,8 +17,6 @@ import java.util.Properties; import java.util.Random; import java.util.Set; import java.util.TreeSet; -import java.util.concurrent.BrokenBarrierException; -import java.util.concurrent.Callable; import java.util.concurrent.CancellationException; import java.util.concurrent.CountDownLatch; import java.util.concurrent.CyclicBarrier; @@ -60,7 +58,6 @@ import com.gemstone.gemfire.internal.cache.DiskStoreImpl; import com.gemstone.gemfire.internal.cache.GemFireCacheImpl; import com.gemstone.gemfire.internal.cache.PartitionedRegion; import com.gemstone.gemfire.internal.cache.PartitionedRegionDataStore; -import com.gemstone.gemfire.internal.cache.control.InternalResourceManager; import com.gemstone.gemfire.internal.cache.control.InternalResourceManager.ResourceObserverAdapter; import dunit.AsyncInvocation; @@ -1087,8 +1084,19 @@ public class RebalanceOperationDUnitTest extends CacheTestCase { } } - public void testRecoverRedundancyParallelAsyncEventQueueSimulation() { - recoverRedundancyParallelAsyncEventQueue(true); + public void testRecoverRedundancyParallelAsyncEventQueueSimulation() throws NoSuchFieldException, SecurityException { + invokeInEveryVM(new SerializableRunnable() { + + @Override + public void run () { + System.setProperty("gemfire.LOG_REBALANCE", "true"); + } + }); + try { + recoverRedundancyParallelAsyncEventQueue(true); + } finally { + System.setProperty("gemfire.LOG_REBALANCE", "false"); + } } public void testRecoverRedundancyParallelAsyncEventQueue() { @@ -1862,17 +1870,6 @@ public class RebalanceOperationDUnitTest extends CacheTestCase { * are correct and we still rebalance correctly */ public void testMoveBucketsOverflowToDisk() throws Throwable { - - System.setProperty("gemfire.LOG_REBALANCE", "true"); - invokeInEveryVM(new SerializableCallable() { - - @Override - public Object call() throws Exception { - System.setProperty("gemfire.LOG_REBALANCE", "true"); - return null; - } - }); - Host host = Host.getHost(0); VM vm0 = host.getVM(0); VM vm1 = host.getVM(1);