Skip to content

Commit

Permalink
[BACKPORT 2.20.2][#20919] docdb: fix leaderless tablet endpoint for R…
Browse files Browse the repository at this point in the history
…F-1 setup

Summary:
Original commit: 4113566 / D32180
For rf-1 setup, leader's ht lease reported to the master is constantly `InfiniteWatermarkForLocalPeer` (max of uint64_t).
So condition `ht_lease_exp > existing_leader_lease_info->ht_lease_expiration` can only pass once at the first time the master received the metrics containing this tablet.

Fix this condition to also cover `ht_lease_exp == existing_leader_lease_info->ht_lease_expiration`.
Jira: DB-9900

Test Plan:
MasterPathHandlersLeaderlessRF1ITest.TestRF1
MasterPathHandlersLeaderlessRF3ITest.*

Reviewers: asrivastava

Reviewed By: asrivastava

Subscribers: ybase, bogdan

Tags: #jenkins-ready

Differential Revision: https://phorge.dev.yugabyte.com/D32563
  • Loading branch information
Huqicheng committed Feb 21, 2024
1 parent 8a4cc8c commit b7dd3a7
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 6 deletions.
49 changes: 44 additions & 5 deletions src/yb/integration-tests/master_path_handlers-itest.cc
Original file line number Diff line number Diff line change
Expand Up @@ -674,15 +674,23 @@ class MasterPathHandlersExternalItest : public MasterPathHandlersBaseItest<Exter
opts_.extra_tserver_flags.push_back("--placement_zone=z${index}");
opts_.extra_tserver_flags.push_back("--placement_uuid=" + kLivePlacementUuid);
opts_.extra_tserver_flags.push_back("--follower_unavailable_considered_failed_sec=10");
const auto rf = opts_.replication_factor > 0 ? opts_.replication_factor : 3;
opts_.extra_master_flags.push_back(Format("--replication_factor=$0", rf));

MasterPathHandlersBaseItest<ExternalMiniCluster>::SetUp();

yb_admin_client_ = std::make_unique<tools::ClusterAdminClient>(
cluster_->GetMasterAddresses(), MonoDelta::FromSeconds(30));
ASSERT_OK(yb_admin_client_->Init());

// 3 live replicas, one in each zone.
ASSERT_OK(yb_admin_client_->ModifyPlacementInfo("c.r.z0:1,c.r.z1:1,c.r.z2:1", 3,
std::string placement_infos;
for (int i = 0; i < rf; i++) {
placement_infos += Format("c.r.z$0:1", i);
if (i < rf - 1) {
placement_infos += ",";
}
}
ASSERT_OK(yb_admin_client_->ModifyPlacementInfo(placement_infos, rf,
kLivePlacementUuid));
}

Expand Down Expand Up @@ -962,9 +970,18 @@ TEST_F_EX(MasterPathHandlersItest, TestTablePlacementInfo, MasterPathHandlersExt
ASSERT_EQ(table_str.substr(pos + 22, 11), "anotherzone");
}

template <int RF>
class MasterPathHandlersLeaderlessITest : public MasterPathHandlersExternalItest {
protected:
int num_tablet_servers() const override {
return RF;
}
int num_masters() const override {
return RF;
}
public:
void SetUp() override {
opts_.replication_factor = RF;
opts_.extra_tserver_flags.push_back(
{Format("--tserver_heartbeat_metrics_interval_ms=$0", kTserverHeartbeatMetricsIntervalMs)});
MasterPathHandlersExternalItest::SetUp();
Expand Down Expand Up @@ -1011,7 +1028,10 @@ class MasterPathHandlersLeaderlessITest : public MasterPathHandlersExternalItest
static constexpr int kTserverHeartbeatMetricsIntervalMs = 1000;
};

TEST_F(MasterPathHandlersLeaderlessITest, TestLeaderlessTabletEndpoint) {
typedef MasterPathHandlersLeaderlessITest<3> MasterPathHandlersLeaderlessRF3ITest;
typedef MasterPathHandlersLeaderlessITest<1> MasterPathHandlersLeaderlessRF1ITest;

TEST_F(MasterPathHandlersLeaderlessRF3ITest, TestLeaderlessTabletEndpoint) {
ASSERT_OK(cluster_->SetFlagOnMasters("leaderless_tablet_alert_delay_secs", "5"));
CreateSingleTabletTestTable();
auto tablet_id = GetSingleTabletId();
Expand Down Expand Up @@ -1076,7 +1096,7 @@ TEST_F(MasterPathHandlersLeaderlessITest, TestLeaderlessTabletEndpoint) {
}, 20s * kTimeMultiplier, "leaderless tablet endpoint becomes empty"));
}

TEST_F(MasterPathHandlersLeaderlessITest, TestLeaderChange) {
TEST_F(MasterPathHandlersLeaderlessRF3ITest, TestLeaderChange) {
const auto kMaxLeaderLeaseExpiredMs = 5000;
const auto kHtLeaseDurationMs = 2000;
const auto kMaxTabletWithoutValidLeaderMs = 5000;
Expand Down Expand Up @@ -1135,7 +1155,7 @@ TEST_F(MasterPathHandlersLeaderlessITest, TestLeaderChange) {
ASSERT_EQ(result.find(tablet_id), string::npos);
}

TEST_F(MasterPathHandlersLeaderlessITest, TestAllFollowers) {
TEST_F(MasterPathHandlersLeaderlessRF3ITest, TestAllFollowers) {
const auto kMaxTabletWithoutValidLeaderMs = 5000;
ASSERT_OK(cluster_->SetFlagOnMasters("leaderless_tablet_alert_delay_secs",
std::to_string(kMaxTabletWithoutValidLeaderMs / 1000)));
Expand Down Expand Up @@ -1180,6 +1200,25 @@ TEST_F(MasterPathHandlersLeaderlessITest, TestAllFollowers) {
}, 20s * kTimeMultiplier, "leaderless tablet endpoint becomes empty"));
}

TEST_F(MasterPathHandlersLeaderlessRF1ITest, TestRF1) {
const auto kLeaderlessTabletAlertDelaySecs = 5;
ASSERT_OK(cluster_->SetFlagOnMasters("leaderless_tablet_alert_delay_secs",
std::to_string(kLeaderlessTabletAlertDelaySecs)));
CreateSingleTabletTestTable();
auto tablet_id = GetSingleTabletId();

SleepFor((kLeaderlessTabletAlertDelaySecs + 1) * 1s);
string result = GetLeaderlessTabletsString();
ASSERT_EQ(result.find(tablet_id), string::npos);

ASSERT_OK(cluster_->tablet_server(0)->Pause());
SleepFor((kLeaderlessTabletAlertDelaySecs + 1) * 1s);
result = GetLeaderlessTabletsString();
ASSERT_NE(result.find(tablet_id), string::npos);

ASSERT_OK(cluster_->tablet_server(0)->Resume());
}

TEST_F(MasterPathHandlersItest, TestLeaderlessDeletedTablet) {
auto table = CreateTestTable(kNumTablets);
const auto kLeaderlessTabletAlertDelaySecs = 5;
Expand Down
2 changes: 1 addition & 1 deletion src/yb/master/catalog_manager.cc
Original file line number Diff line number Diff line change
Expand Up @@ -13131,7 +13131,7 @@ void CatalogManager::ProcessTabletMetadata(
// If the reported ht lease from the leader is expired for more than
// FLAGS_maximum_tablet_leader_lease_expired_secs, the leader shouldn't be treated
// as a valid leader.
if (ht_lease_exp > existing_leader_lease_info->ht_lease_expiration &&
if (ht_lease_exp >= existing_leader_lease_info->ht_lease_expiration &&
!IsHtLeaseExpiredForTooLong(
master_->clock()->Now().GetPhysicalValueMicros(), ht_lease_exp)) {
tablet->UpdateLastTimeWithValidLeader();
Expand Down

0 comments on commit b7dd3a7

Please sign in to comment.