From 4dd8cf38be263b710eb2c5e14df90322eda6fb0c Mon Sep 17 00:00:00 2001 From: Sun Chenyang Date: Tue, 17 Dec 2024 11:05:01 +0800 Subject: [PATCH] [fix](cloud) fix error in get detached tablet stat (#45449) ### What problem does this PR solve? Related PR: #44120 Problem Summary: - `detached tablet stats` should maintain a fixed size. --- cloud/src/meta-service/keys.h | 6 ++ .../meta_service_tablet_stats.cpp | 10 +- cloud/test/CMakeLists.txt | 1 + cloud/test/meta_service_tablet_stats_test.cpp | 101 ++++++++++++++++++ 4 files changed, 115 insertions(+), 3 deletions(-) create mode 100644 cloud/test/meta_service_tablet_stats_test.cpp diff --git a/cloud/src/meta-service/keys.h b/cloud/src/meta-service/keys.h index 855171c1dc648a..c2c9a9dd4daa15 100644 --- a/cloud/src/meta-service/keys.h +++ b/cloud/src/meta-service/keys.h @@ -254,6 +254,12 @@ void stats_tablet_num_segs_key(const StatsTabletKeyInfo& in, std::string* out); void stats_tablet_index_size_key(const StatsTabletKeyInfo& in, std::string* out); void stats_tablet_segment_size_key(const StatsTabletKeyInfo& in, std::string* out); static inline std::string stats_tablet_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_key(in, &s); return s; } +static inline std::string stats_tablet_data_size_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_data_size_key(in, &s); return s; } +static inline std::string stats_tablet_num_rows_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_num_rows_key(in, &s); return s; } +static inline std::string stats_tablet_num_rowsets_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_num_rowsets_key(in, &s); return s; } +static inline std::string stats_tablet_num_segs_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_num_segs_key(in, &s); return s; } +static inline std::string stats_tablet_index_size_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_index_size_key(in, &s); return s; } +static inline std::string stats_tablet_segment_size_key(const StatsTabletKeyInfo& in) { std::string s; stats_tablet_segment_size_key(in, &s); return s; } void job_recycle_key(const JobRecycleKeyInfo& in, std::string* out); void job_check_key(const JobRecycleKeyInfo& in, std::string* out); diff --git a/cloud/src/meta-service/meta_service_tablet_stats.cpp b/cloud/src/meta-service/meta_service_tablet_stats.cpp index 4cbf629c9a3185..da556b6c574557 100644 --- a/cloud/src/meta-service/meta_service_tablet_stats.cpp +++ b/cloud/src/meta-service/meta_service_tablet_stats.cpp @@ -94,7 +94,8 @@ int get_detached_tablet_stats(const std::vector +#include + +#include "meta-service/codec.h" +#include "meta-service/keys.h" + +namespace doris::cloud { + +std::string size_value(int64_t tablet_stat_data_size) { + std::string tablet_stat_data_size_value(sizeof(tablet_stat_data_size), '\0'); + memcpy(tablet_stat_data_size_value.data(), &tablet_stat_data_size, + sizeof(tablet_stat_data_size)); + return tablet_stat_data_size_value; +} + +TEST(MetaServiceTabletStatsTest, test_get_detached_tablet_stats) { + std::vector> stats_kvs; + StatsTabletKeyInfo tablet_key_info {"instance_0", 10000, 10001, 10002, 10003}; + + // key->TabletStatsPB + TabletStatsPB tablet_stat; + std::string tablet_stat_value; + auto tablet_stat_key = stats_tablet_key(tablet_key_info); + tablet_stat.SerializeToString(&tablet_stat_value); + stats_kvs.emplace_back(tablet_stat_key, tablet_stat_value); + + // key->data_size + auto tablet_stat_data_size_key = stats_tablet_data_size_key(tablet_key_info); + stats_kvs.emplace_back(tablet_stat_data_size_key, size_value(100)); + + // key->num_rows + auto tablet_stat_num_rows_key = stats_tablet_num_rows_key(tablet_key_info); + stats_kvs.emplace_back(tablet_stat_num_rows_key, size_value(10)); + + // key->num_rowsets + auto tablet_stat_num_rowsets_key = stats_tablet_num_rowsets_key(tablet_key_info); + stats_kvs.emplace_back(tablet_stat_num_rowsets_key, size_value(1)); + + // key->num_segs + auto tablet_stat_num_segs_key = stats_tablet_num_segs_key(tablet_key_info); + stats_kvs.emplace_back(tablet_stat_num_segs_key, size_value(1)); + + // key->index_size + auto tablet_stat_index_size_key = stats_tablet_index_size_key(tablet_key_info); + stats_kvs.emplace_back(tablet_stat_index_size_key, size_value(50)); + + // key->segment_size + auto tablet_stat_segment_size_key = stats_tablet_segment_size_key(tablet_key_info); + stats_kvs.emplace_back(tablet_stat_segment_size_key, size_value(50)); + + TabletStats res1; + int ret = get_detached_tablet_stats(stats_kvs, res1); + EXPECT_EQ(ret, 0); + EXPECT_EQ(res1.data_size, 100); + EXPECT_EQ(res1.num_rows, 10); + EXPECT_EQ(res1.num_rowsets, 1); + EXPECT_EQ(res1.num_segs, 1); + EXPECT_EQ(res1.index_size, 50); + EXPECT_EQ(res1.segment_size, 50); + + stats_kvs.resize(5); + TabletStats res2; + ret = get_detached_tablet_stats(stats_kvs, res2); + EXPECT_EQ(ret, 0); + EXPECT_EQ(res1.data_size, 100); + EXPECT_EQ(res1.num_rows, 10); + EXPECT_EQ(res1.num_rowsets, 1); + EXPECT_EQ(res1.num_segs, 1); + + stats_kvs.resize(2); + TabletStats res3; + ret = get_detached_tablet_stats(stats_kvs, res3); + EXPECT_EQ(ret, 0); + EXPECT_EQ(res1.data_size, 100); + + stats_kvs.resize(1); + TabletStats res4; + ret = get_detached_tablet_stats(stats_kvs, res4); + EXPECT_EQ(ret, 0); +} + +} // namespace doris::cloud