Skip to content

Commit

Permalink
chore: apply suggestions from CR
Browse files Browse the repository at this point in the history
  • Loading branch information
WenyXu committed Nov 27, 2023
1 parent 2f8ad55 commit e816be4
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 14 deletions.
4 changes: 2 additions & 2 deletions src/meta-srv/src/procedure/region_migration.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,8 +98,8 @@ impl VolatileContext {
}

/// Resets the `leader_region_lease_deadline`.
pub fn reset_leader_region_lease_deadline(&mut self, deadline: Instant) {
self.leader_region_lease_deadline = Some(deadline);
pub fn reset_leader_region_lease_deadline(&mut self) {
self.leader_region_lease_deadline = None;
}

/// Sets the `leader_region_last_entry_id`.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ use common_meta::instruction::{
use common_telemetry::warn;
use serde::{Deserialize, Serialize};
use snafu::ResultExt;
use tokio::time::{sleep, Instant};
use tokio::time::sleep;

use super::upgrade_candidate_region::UpgradeCandidateRegion;
use crate::error::{self, Result};
Expand Down Expand Up @@ -60,8 +60,9 @@ impl State for DowngradeLeaderRegion {
self.downgrade_region_with_retry(ctx).await;

// Safety: must exist.
let deadline = ctx.volatile_ctx.leader_region_lease_deadline.unwrap();
tokio::time::sleep_until(deadline).await;
if let Some(deadline) = ctx.volatile_ctx.leader_region_lease_deadline.as_ref() {
tokio::time::sleep_until(*deadline).await;
}

Ok(Box::new(UpgradeCandidateRegion))
}
Expand Down Expand Up @@ -179,19 +180,18 @@ impl DowngradeLeaderRegion {

let mut retry = 0;

while retry < self.optimistic_retry {
loop {
if let Err(err) = self.downgrade_region(ctx, &instruction).await {
if err.is_retryable() {
warn!("Failed to downgrade region, error: {err:?}, retry later.");
retry += 1;
if err.is_retryable() && retry < self.optimistic_retry {
warn!("Failed to downgrade region, error: {err:?}, retry later");
sleep(self.retry_initial_interval).await;
retry += 1;
} else {
break;
}
} else {
// Sets the deadline to now.
ctx.volatile_ctx
.reset_leader_region_lease_deadline(Instant::now());
// Resets the deadline.
ctx.volatile_ctx.reset_leader_region_lease_deadline();
break;
}
}
Expand Down Expand Up @@ -433,7 +433,7 @@ mod tests {

state.downgrade_region_with_retry(&mut ctx).await;
assert_eq!(ctx.volatile_ctx.leader_region_last_entry_id, Some(1));
assert!(ctx.volatile_ctx.leader_region_lease_deadline.unwrap() < Instant::now())
assert!(ctx.volatile_ctx.leader_region_lease_deadline.is_none());
}

#[tokio::test]
Expand Down Expand Up @@ -508,7 +508,7 @@ mod tests {
let elapsed = timer.elapsed().as_secs();
assert!(elapsed < REGION_LEASE_SECS / 2);
assert_eq!(ctx.volatile_ctx.leader_region_last_entry_id, Some(1));
assert!(ctx.volatile_ctx.leader_region_lease_deadline.unwrap() < Instant::now());
assert!(ctx.volatile_ctx.leader_region_lease_deadline.is_none());

let _ = next
.as_any()
Expand Down

0 comments on commit e816be4

Please sign in to comment.