This is an automated email from the ASF dual-hosted git repository.

tanxinyu pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/iotdb.git


The following commit(s) were added to refs/heads/master by this push:
     new dba32d6b0f3 Fix confignode restart Error (#10750)
dba32d6b0f3 is described below

commit dba32d6b0f30c1456d9abe4521bbb52df8993212
Author: Potato <[email protected]>
AuthorDate: Tue Aug 1 12:26:47 2023 +0800

    Fix confignode restart Error (#10750)
---
 .../java/org/apache/iotdb/confignode/manager/load/LoadManager.java | 5 +++++
 .../manager/load/balancer/partition/DataPartitionPolicyTable.java  | 7 ++++++-
 .../java/org/apache/iotdb/confignode/manager/node/NodeManager.java | 3 +++
 3 files changed, 14 insertions(+), 1 deletion(-)

diff --git 
a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java
 
b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java
index b4c291c97e9..450a19adad2 100644
--- 
a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java
+++ 
b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/LoadManager.java
@@ -130,6 +130,11 @@ public class LoadManager {
     return 
partitionBalancer.allocateDataPartition(unassignedDataPartitionSlotsMap);
   }
 
+  /**
+   * Re-balance the DataPartitionPolicyTable.
+   *
+   * @param database Database name
+   */
   public void reBalanceDataPartitionPolicy(String database) {
     partitionBalancer.reBalanceDataPartitionPolicy(database);
   }
diff --git 
a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/partition/DataPartitionPolicyTable.java
 
b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/partition/DataPartitionPolicyTable.java
index 29bd2a2c1ba..ba367792448 100644
--- 
a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/partition/DataPartitionPolicyTable.java
+++ 
b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/load/balancer/partition/DataPartitionPolicyTable.java
@@ -78,6 +78,11 @@ public class DataPartitionPolicyTable {
    * @param dataRegionGroups All DataRegionGroups currently in the Database
    */
   public void reBalanceDataPartitionPolicy(List<TConsensusGroupId> 
dataRegionGroups) {
+    if (dataRegionGroups.isEmpty()) {
+      // No need to re-balance when there is no DataRegionGroup
+      return;
+    }
+
     dataAllotTableLock.lock();
     try {
       dataRegionGroups.forEach(
@@ -120,7 +125,7 @@ public class DataPartitionPolicyTable {
       int mu = SERIES_SLOT_NUM / seriesPartitionSlotCounter.size();
       dataAllotMap.forEach(
           (seriesPartitionSlot, regionGroupId) -> {
-            if (seriesPartitionSlotCounter.get(regionGroupId) < mu) {
+            if (regionGroupId != null && 
seriesPartitionSlotCounter.get(regionGroupId) < mu) {
               // Put into dataAllotMap only when the number of SeriesSlots
               // allocated to the RegionGroup is less than mu
               this.dataAllotMap.put(seriesPartitionSlot, regionGroupId);
diff --git 
a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/node/NodeManager.java
 
b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/node/NodeManager.java
index 55d3ab05345..1ed797f6fdd 100644
--- 
a/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/node/NodeManager.java
+++ 
b/iotdb-core/confignode/src/main/java/org/apache/iotdb/confignode/manager/node/NodeManager.java
@@ -364,6 +364,9 @@ public class NodeManager {
       UpdateVersionInfoPlan updateConfigNodePlan =
           new UpdateVersionInfoPlan(versionInfo, configNodeId);
       ConsensusWriteResponse result = 
getConsensusManager().write(updateConfigNodePlan);
+      if (result.getException() != null) {
+        return new 
TSStatus(TSStatusCode.CONSENSUS_NOT_INITIALIZED.getStatusCode());
+      }
       return result.getStatus();
     }
     return ClusterNodeStartUtils.ACCEPT_NODE_RESTART;

Reply via email to