forked from opencurve/curve
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcurvefs_partition_list.cpp
109 lines (93 loc) · 3.19 KB
/
curvefs_partition_list.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
* Copyright (c) 2022 NetEase Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* Project: curve
* Created Date: 2022-04-29
* Author: chengyi01
*/
#include "curvefs/src/tools/list/curvefs_partition_list.h"
#include <json/json.h>
#include <fstream>
#include <iostream>
#include <memory>
#include <string>
#include <vector>
#include "curvefs/src/tools/curvefs_tool_define.h"
#include "src/common/string_util.h"
DECLARE_string(mdsAddr);
DECLARE_string(fsId);
namespace curvefs {
namespace tools {
namespace list {
void PartitionListTool::PrintHelp() {
CurvefsToolRpc::PrintHelp();
std::cout << " -fsId=" << FLAGS_fsId << " [-mdsAddr=" << FLAGS_mdsAddr
<< "]" << std::endl;
}
void PartitionListTool::AddUpdateFlags() {
AddUpdateFlagsFunc(curvefs::tools::SetMdsAddr);
}
int PartitionListTool::Init() {
if (CurvefsToolRpc::Init() != 0) {
return -1;
}
curve::common::SplitString(FLAGS_mdsAddr, ",", &hostsAddr_);
google::CommandLineFlagInfo info;
if (CheckFsIdDefault(&info)) {
std::cerr << "no -fsId=*, please use --example check!" << std::endl;
return -1;
}
std::vector<std::string> fsIds;
curve::common::SplitString(FLAGS_fsId, ",", &fsIds);
service_stub_func_ =
std::bind(&curvefs::mds::topology::TopologyService_Stub::ListPartition,
service_stub_.get(), std::placeholders::_1,
std::placeholders::_2, std::placeholders::_3, nullptr);
curvefs::mds::topology::ListPartitionRequest request;
for (const auto& i : fsIds) {
uint32_t fsId = 0;
curve::common::StringToUl(i, &fsId);
request.set_fsid(fsId);
AddRequest(request);
}
return 0;
}
bool PartitionListTool::AfterSendRequestToHost(const std::string& host) {
bool ret = false;
if (controller_->Failed()) {
errorOutput_ << "get fsinfo from mds: " << host
<< " failed, errorcode= " << controller_->ErrorCode()
<< ", error text " << controller_->ErrorText() << "\n";
} else {
if (response_->statuscode() != mds::topology::TopoStatusCode::TOPO_OK) {
std::cerr << "list partitions failed, errorcode= "
<< mds::topology::TopoStatusCode_Name(
response_->statuscode())
<< std::endl;
} else {
fsId2PartitionList_[requestQueue_.front().fsid()] =
response_->partitioninfolist();
if (show_) {
std::cout << response_->DebugString() << std::endl;
ret = true;
}
}
}
return ret;
}
} // namespace list
} // namespace tools
} // namespace curvefs