Skip to content

Commit

Permalink
Add metadata cache configuration flags behind build-time feature (#559)
Browse files Browse the repository at this point in the history
Signed-off-by: Daniel Carl Jones <[email protected]>
  • Loading branch information
dannycjones authored Oct 17, 2023
1 parent a50f1ca commit fb11476
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 1 deletion.
4 changes: 4 additions & 0 deletions mountpoint-s3/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,10 @@ tokio = { version = "1.24.2", features = ["rt", "macros"] }
walkdir = "2.3.3"

[features]
# Experimental features
caching = []

# Test features
fips_tests = []
fuse_tests = []
s3_tests = []
Expand Down
43 changes: 42 additions & 1 deletion mountpoint-s3/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ use std::time::Duration;
use anyhow::{anyhow, Context as _};
use clap::{value_parser, Parser};
use fuser::{MountOption, Session};
use mountpoint_s3::fs::S3FilesystemConfig;
use mountpoint_s3::fs::{CacheConfig, S3FilesystemConfig};
use mountpoint_s3::fuse::session::FuseSession;
use mountpoint_s3::fuse::S3FuseFilesystem;
use mountpoint_s3::instance::InstanceInfo;
Expand All @@ -33,6 +33,8 @@ const MOUNT_OPTIONS_HEADER: &str = "Mount options";
const BUCKET_OPTIONS_HEADER: &str = "Bucket options";
const AWS_CREDENTIALS_OPTIONS_HEADER: &str = "AWS credentials options";
const LOGGING_OPTIONS_HEADER: &str = "Logging options";
#[cfg(feature = "caching")]
const CACHING_OPTIONS_HEADER: &str = "Caching options";

#[derive(Parser)]
#[clap(name = "mount-s3", about = "Mountpoint for Amazon S3", version = build_info::FULL_VERSION)]
Expand Down Expand Up @@ -214,6 +216,26 @@ struct CliArgs {
conflicts_with_all(["log_directory", "debug", "debug_crt", "log_metrics"])
)]
pub no_log: bool,

#[cfg(feature = "caching")]
#[clap(
long,
help = "Enable caching of file and directory metadata for a configurable time-to-live (TTL)",
help_heading = CACHING_OPTIONS_HEADER,
)]
pub enable_metadata_caching: bool,

// TODO: What is a sensible default? Should TTL even be configurable?
#[cfg(feature = "caching")]
#[clap(
long,
help = "Override time-to-live (TTL) for cached metadata entries in seconds",
value_name = "SECONDS",
value_parser = parse_duration_seconds,
help_heading = CACHING_OPTIONS_HEADER,
requires = "enable_metadata_caching",
)]
pub metadata_cache_ttl: Option<Duration>,
}

impl CliArgs {
Expand Down Expand Up @@ -463,6 +485,19 @@ fn mount(args: CliArgs) -> anyhow::Result<FuseSession> {
filesystem_config.storage_class = args.storage_class;
filesystem_config.allow_delete = args.allow_delete;

#[cfg(feature = "caching")]
{
if args.enable_metadata_caching {
// TODO: Review default for TTL
let metadata_cache_ttl = args.metadata_cache_ttl.unwrap_or(Duration::from_secs(3600));
filesystem_config.cache_config = CacheConfig {
prefer_s3: false,
dir_ttl: metadata_cache_ttl,
file_ttl: metadata_cache_ttl,
};
}
}

let fs = S3FuseFilesystem::new(client, runtime, &args.bucket_name, &prefix, filesystem_config);

let fs_name = String::from("mountpoint-s3");
Expand Down Expand Up @@ -580,6 +615,12 @@ fn parse_bucket_name(bucket_name: &str) -> anyhow::Result<String> {
Ok(bucket_name.to_owned())
}

fn parse_duration_seconds(seconds_str: &str) -> anyhow::Result<Duration> {
let seconds = seconds_str.parse()?;
let duration = Duration::from_secs(seconds);
Ok(duration)
}

fn env_region() -> Option<String> {
env::var_os("AWS_REGION").map(|val| val.to_string_lossy().into())
}
Expand Down

0 comments on commit fb11476

Please sign in to comment.