Skip to content

Commit

Permalink
chore: Add timeout setting for find_ttl.
Browse files Browse the repository at this point in the history
  • Loading branch information
linyihai committed Dec 4, 2024
1 parent 5bdea1a commit 56707cd
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 7 deletions.
19 changes: 12 additions & 7 deletions src/mito2/src/compaction.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,9 @@ use crate::compaction::picker::{new_picker, CompactionTask};
use crate::compaction::task::CompactionTaskImpl;
use crate::config::MitoConfig;
use crate::error::{
CompactRegionSnafu, Error, GetSchemaMetadataSnafu, RegionClosedSnafu, RegionDroppedSnafu,
RegionTruncatedSnafu, RemoteCompactionSnafu, Result, TimeRangePredicateOverflowSnafu,
CompactRegionSnafu, Error, FetchTtLTimeoutSnafu, GetSchemaMetadataSnafu, RegionClosedSnafu,
RegionDroppedSnafu, RegionTruncatedSnafu, RemoteCompactionSnafu, Result,
TimeRangePredicateOverflowSnafu,
};
use crate::metrics::COMPACTION_STAGE_ELAPSED;
use crate::read::projection::ProjectionMapper;
Expand Down Expand Up @@ -444,11 +445,15 @@ async fn find_ttl(
return Ok(Some(table_ttl));
}

let ttl = schema_metadata_manager
.get_schema_options_by_table_id(table_id)
.await
.context(GetSchemaMetadataSnafu)?
.and_then(|options| options.ttl);
let ttl = tokio::time::timeout(
crate::config::FETCH_TTL_TIMEOUT,
schema_metadata_manager.get_schema_options_by_table_id(table_id),
)
.await
.context(FetchTtLTimeoutSnafu)?
.context(GetSchemaMetadataSnafu)?
.and_then(|options| options.ttl);

Ok(ttl)
}

Expand Down
3 changes: 3 additions & 0 deletions src/mito2/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,9 @@ const PAGE_CACHE_SIZE_FACTOR: u64 = 8;
/// Use `1/INDEX_CREATE_MEM_THRESHOLD_FACTOR` of OS memory size as mem threshold for creating index
const INDEX_CREATE_MEM_THRESHOLD_FACTOR: u64 = 16;

/// Fetch TTL timeout
pub(crate) const FETCH_TTL_TIMEOUT: Duration = Duration::from_secs(10);

/// Configuration for [MitoEngine](crate::engine::MitoEngine).
#[derive(Debug, Serialize, Deserialize, Clone, PartialEq, Eq)]
#[serde(default)]
Expand Down
10 changes: 10 additions & 0 deletions src/mito2/src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ use snafu::{Location, Snafu};
use store_api::logstore::provider::Provider;
use store_api::manifest::ManifestVersion;
use store_api::storage::RegionId;
use tokio::time::error::Elapsed;

use crate::cache::file_cache::FileType;
use crate::region::{RegionLeaderState, RegionRoleState};
Expand Down Expand Up @@ -877,6 +878,14 @@ pub enum Error {
#[snafu(implicit)]
location: Location,
},

#[snafu(display("Fetch TTL timeout"))]
FetchTtLTimeout {
#[snafu(source)]
error: Elapsed,
#[snafu(implicit)]
location: Location,
},
}

pub type Result<T, E = Error> = std::result::Result<T, E>;
Expand Down Expand Up @@ -1010,6 +1019,7 @@ impl ErrorExt for Error {
DecodeStats { .. } | StatsNotPresent { .. } => StatusCode::Internal,
RegionBusy { .. } => StatusCode::RegionBusy,
GetSchemaMetadata { source, .. } => source.status_code(),
FetchTtLTimeout { .. } => StatusCode::Cancelled,
}
}

Expand Down

0 comments on commit 56707cd

Please sign in to comment.