Skip to content

Commit

Permalink
chunkserver : fix bug in trash when collecting chunknum miss chunk in…
Browse files Browse the repository at this point in the history
… raft_snapshot dir
  • Loading branch information
xu-chaojie committed Jul 8, 2021
1 parent 7800ea6 commit a2f5577
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 18 deletions.
32 changes: 18 additions & 14 deletions src/chunkserver/trash.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -306,27 +306,31 @@ bool Trash::IsWALFile(const std::string &fileName) {
}

uint32_t Trash::CountChunkNumInCopyset(const std::string &copysetPath) {
auto count = [&](const std::string& path) {
std::vector<std::string> chunks;
localFileSystem_->List(path, &chunks);
std::vector<std::string> files;
if (0 != localFileSystem_->List(copysetPath, &files)) {
LOG(ERROR) << "Trash failed to list files in " << copysetPath;
return 0;
}

uint32_t chunkNum = 0;
for (auto& chunk : chunks) {
// 遍历子文件
uint32_t chunkNum = 0;
for (auto &file : files) {
std::string filePath = copysetPath + "/" + file;
bool isDir = localFileSystem_->DirExists(filePath);
if (!isDir) {
// valid: chunkfile, snapshotfile, walfile
if (!(IsChunkOrSnapShotFile(chunk) || IsWALFile(chunk))) {
if (!(IsChunkOrSnapShotFile(file) ||
IsWALFile(file))) {
LOG(WARNING) << "Trash find a illegal file:"
<< chunk << " in " << path
<< ", filename: " << chunk;
<< file << " in " << copysetPath;
continue;
}
++chunkNum;
} else {
chunkNum += CountChunkNumInCopyset(filePath);
}

return chunkNum;
};

return count(copysetPath + "/" + RAFT_DATA_DIR)
+ count(copysetPath + "/" + RAFT_LOG_DIR);
}
return chunkNum;
}

} // namespace chunkserver
Expand Down
49 changes: 45 additions & 4 deletions test/chunkserver/trash_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -557,7 +557,6 @@ TEST_F(TrashTest, recycle_copyset_dir_list_err) {
EXPECT_CALL(*lfs, Mkdir(trashPath)).WillOnce(Return(0));
EXPECT_CALL(*lfs, Rename(dirPath, _, 0)).WillOnce(Return(0));
EXPECT_CALL(*lfs, List(_, _))
.WillOnce(Return(-1))
.WillOnce(Return(-1));
ASSERT_EQ(0, trash->RecycleCopySet(dirPath));
}
Expand All @@ -571,7 +570,6 @@ TEST_F(TrashTest, recycle_copyset_dir_ok) {
EXPECT_CALL(*lfs, Mkdir(trashPath)).WillOnce(Return(0));
EXPECT_CALL(*lfs, Rename(dirPath, _, 0)).WillOnce(Return(0));
EXPECT_CALL(*lfs, List(_, _))
.WillOnce(Return(0))
.WillOnce(Return(0));
ASSERT_EQ(0, trash->RecycleCopySet(dirPath));
}
Expand All @@ -586,6 +584,7 @@ TEST_F(TrashTest, DISABLED_test_concurrenct) {
TEST_F(TrashTest, test_chunk_num_statistic) {
std::string trashPath = "./runlog/trash_test0/trash";
std::vector<std::string> copysets{"4294967493.55555", "4294967494.55555"};
std::vector<std::string> dirs{"data", "log"};
std::vector<std::string> chunks1{"chunk_100", "chunk_101"};
std::vector<std::string> chunks2{"chunk_200_snap_1", "abc"};
std::vector<std::string> logfiles1{
Expand All @@ -594,14 +593,30 @@ TEST_F(TrashTest, test_chunk_num_statistic) {
std::vector<std::string> logfiles2{};

// (1) chunk exists when init
// trash/
// 4294967493.55555/
// data/
// chunk_100, chunk_101 +2
// log/
// curve_log_10086_10087, +1
// curve_log_inprogress_10088, +1
// log_10083_10084,
// log_inprogress_10085
// 4294967494.55555/
// data/
// chunk_200_snap_1, abc +1
// log/

using item4list = struct{
std::string subdir;
std::vector<std::string>& names;
};
std::vector<item4list> action4List{
{ "", copysets },
{ "/4294967493.55555", dirs},
{ "/4294967493.55555/data", chunks1 },
{ "/4294967493.55555/log", logfiles1 },
{ "/4294967494.55555", dirs},
{ "/4294967494.55555/data", chunks2 },
{ "/4294967494.55555/log", logfiles2 },
};
Expand All @@ -611,20 +626,46 @@ TEST_F(TrashTest, test_chunk_num_statistic) {
.WillOnce(DoAll(SetArgPointee<1>(it.names), Return(0)));
}

EXPECT_CALL(*lfs, DirExists(_))
.WillOnce(Return(true)) // data
.WillOnce(Return(false)) // chunk_100
.WillOnce(Return(false)) // chunk_101
.WillOnce(Return(true)) // log
.WillOnce(Return(false)) // curve_log_10086_10087
.WillOnce(Return(false)) // curve_log_inprogress_10088_10088
.WillOnce(Return(false)) // log_10083_10084
.WillOnce(Return(false)) // log_inprogress_10085
.WillOnce(Return(true)) // data
.WillOnce(Return(false)) // chunk_200_snap_1
.WillOnce(Return(false)) // abc
.WillOnce(Return(true)); // log

trash->Init(ops);
ASSERT_EQ(5, trash->GetChunkNum());

// (2) recycle copyset
std::string copysetDir = "./runlog/trash_test0/copysets/4294967495";
// trash_test0/copysets/4294967495/
// data/
// chunk_333, chunk_444 +2
// log/
// curve_log_10086_10087 +1
//
std::string copysetDir = "/copysets/4294967495";
EXPECT_CALL(*lfs, DirExists(_))
.WillOnce(Return(true))
.WillOnce(Return(false))
.WillOnce(Return(true)) // data
.WillOnce(Return(false))
.WillOnce(Return(false))
.WillOnce(Return(true)) // log
.WillOnce(Return(false));
std::string trashedCopysetDir;
std::string trashedCopysetDir = "/trash_test0/copysets/4294967495";
EXPECT_CALL(*lfs, Rename(copysetDir, _, 0))
.WillOnce(DoAll(SaveArg<1>(&trashedCopysetDir), Return(0)));
std::vector<std::string> chunks3{"chunk_333", "chunk_444"};
std::vector<std::string> logfiles3{"curve_log_10086_10087"};
EXPECT_CALL(*lfs, List(_, _))
.WillOnce(DoAll(SetArgPointee<1>(dirs), Return(0)))
.WillOnce(DoAll(SetArgPointee<1>(chunks3), Return(0)))
.WillOnce(DoAll(SetArgPointee<1>(logfiles3), Return(0)));
ASSERT_EQ(0, trash->RecycleCopySet(copysetDir));
Expand Down

0 comments on commit a2f5577

Please sign in to comment.