From b9c411825e153119b22528cc691ebcdac24b9a14 Mon Sep 17 00:00:00 2001 From: lixiaocui1 Date: Thu, 5 Aug 2021 15:01:06 +0800 Subject: [PATCH] fix/chunkserver: config change epoch update error --- src/chunkserver/copyset_node.cpp | 6 ++++++ test/chunkserver/heartbeat_test_common.cpp | 3 +++ 2 files changed, 9 insertions(+) diff --git a/src/chunkserver/copyset_node.cpp b/src/chunkserver/copyset_node.cpp index ee31dfc25e..a481a20f42 100755 --- a/src/chunkserver/copyset_node.cpp +++ b/src/chunkserver/copyset_node.cpp @@ -65,6 +65,7 @@ CopysetNode::CopysetNode(const LogicPoolID &logicPoolId, chunkDataRpath_(), appliedIndex_(0), leaderTerm_(-1), + lastSnapshotIndex_(0), configChange_(std::make_shared()) { } @@ -434,7 +435,10 @@ int CopysetNode::on_snapshot_load(::braft::SnapshotReader *reader) { conf_.add_peer(meta.peers(i)); } } + + LOG(INFO) << "update lastSnapshotIndex_ from " << lastSnapshotIndex_; lastSnapshotIndex_ = meta.last_included_index(); + LOG(INFO) << "to lastSnapshotIndex_: " << lastSnapshotIndex_; return 0; } @@ -465,6 +469,8 @@ void CopysetNode::on_configuration_committed(const Configuration& conf, // This function is also called when loading snapshot. // Loading snapshot should not increase epoch. When loading // snapshot, the index is equal with lastSnapshotIndex_. + LOG(INFO) << "index: " << index + << ", lastSnapshotIndex_: " << lastSnapshotIndex_; if (index != lastSnapshotIndex_) { std::unique_lock lock_guard(confLock_); conf_ = conf; diff --git a/test/chunkserver/heartbeat_test_common.cpp b/test/chunkserver/heartbeat_test_common.cpp index 553e84b0ad..146d354ac9 100644 --- a/test/chunkserver/heartbeat_test_common.cpp +++ b/test/chunkserver/heartbeat_test_common.cpp @@ -351,6 +351,9 @@ bool HeartbeatTestCommon::WailForConfigChangeOk( if (SameCopySetInfo(req->copysetinfos(0), expectedInfo)) { return true; } + LOG(INFO) << "req->copysetinfos:" + << req->copysetinfos(0).DebugString() + << ", expectedInfo: " << expectedInfo.DebugString(); } else if (req->copysetinfos_size() == 0) { if (SameCopySetInfo( ::curve::mds::heartbeat::CopySetInfo{}, expectedInfo)) {