From 130c8ce8a05848693aa2d47d5bd38c965f0d3ad1 Mon Sep 17 00:00:00 2001 From: Arpad Borsos Date: Fri, 16 Feb 2024 12:51:41 +0100 Subject: [PATCH] Make stresstest observability configurable (#1375) --- crates/symbolicator-stress/src/logging.rs | 3 +-- crates/symbolicator-stress/src/main.rs | 26 +++++++++++++++++------ 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/crates/symbolicator-stress/src/logging.rs b/crates/symbolicator-stress/src/logging.rs index 2a50a2a1c..c5479b5c1 100644 --- a/crates/symbolicator-stress/src/logging.rs +++ b/crates/symbolicator-stress/src/logging.rs @@ -61,8 +61,7 @@ pub fn init(config: Config) -> Guard { } if config.tracing { - // we will log DEBUG output - let rust_log = "INFO,symbolicator=DEBUG"; + let rust_log = "INFO"; let subscriber = fmt() .with_timer(UtcTime::rfc_3339()) .with_target(true) diff --git a/crates/symbolicator-stress/src/main.rs b/crates/symbolicator-stress/src/main.rs index 6280a9cfb..e353313d7 100644 --- a/crates/symbolicator-stress/src/main.rs +++ b/crates/symbolicator-stress/src/main.rs @@ -25,16 +25,28 @@ static GLOBAL: Jemalloc = Jemalloc; #[derive(Parser)] struct Cli { /// Path to your configuration file. - #[arg(long = "config", short = 'c', value_name = "FILE")] + #[arg(long, short, value_name = "FILE")] config: Option, /// Path to the workload definition file. - #[arg(long = "workloads", short = 'w', value_name = "FILE")] + #[arg(long, short, value_name = "FILE")] workloads: PathBuf, /// Duration of the stresstest. - #[arg(long = "duration", short = 'd', value_parser = parse_duration)] + #[arg(long, short, value_parser = parse_duration)] duration: Duration, + + /// Register a `tracing` subscriber. + #[arg(long, short)] + tracing: bool, + + /// Enable Sentry, capturing breadcrumbs and `tracing` spans if that is enabled as well. + #[arg(long, short)] + sentry: bool, + + /// Register a metrics sink. + #[arg(long, short)] + metrics: bool, } fn main() -> Result<()> { @@ -50,15 +62,15 @@ fn main() -> Result<()> { let service_config = SymbolicatorConfig::get(config_path.as_deref())?; let mut logging_guard = logging::init(logging::Config { - // TODO: actually make this configurable backtraces: true, - tracing: true, - sentry: true, - metrics: true, + tracing: cli.tracing, + sentry: cli.sentry, + metrics: cli.metrics, }); let megs = 1024 * 1024; let runtime = tokio::runtime::Builder::new_multi_thread() + .thread_name("stresstest") .enable_all() .thread_stack_size(8 * megs) .build()?;