diff --git a/.vscode/settings.json b/.vscode/settings.json index 4106d65e9cab..29574782cbf0 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -42,4 +42,4 @@ "ukey", "Ukey" ] -} \ No newline at end of file +} diff --git a/Cargo.lock b/Cargo.lock index 1062c86508a2..35b1bc6d809e 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -192,6 +192,28 @@ dependencies = [ "tokio", ] +[[package]] +name = "async-stream" +version = "0.3.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b5a71a6f37880a80d1d7f19efd781e4b5de42c88f0722cc13bcb6cc2cfe8476" +dependencies = [ + "async-stream-impl", + "futures-core", + "pin-project-lite", +] + +[[package]] +name = "async-stream-impl" +version = "0.3.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c7c24de15d275a1ecfd47a380fb4d5ec9bfe0933f309ed5e705b775596a3574d" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.95", +] + [[package]] name = "async-trait" version = "0.1.84" @@ -212,6 +234,12 @@ dependencies = [ "critical-section", ] +[[package]] +name = "atomic-waker" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0" + [[package]] name = "auto_impl" version = "1.2.0" @@ -229,6 +257,53 @@ version = "1.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26" +[[package]] +name = "axum" +version = "0.7.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "edca88bc138befd0323b20752846e6587272d3b03b0343c8ea28a6f819e6e71f" +dependencies = [ + "async-trait", + "axum-core", + "bytes", + "futures-util", + "http", + "http-body", + "http-body-util", + "itoa", + "matchit", + "memchr", + "mime", + "percent-encoding", + "pin-project-lite", + "rustversion", + "serde", + "sync_wrapper 1.0.2", + "tower 0.5.1", + "tower-layer", + "tower-service", +] + +[[package]] +name = "axum-core" +version = "0.4.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "09f2bd6146b97ae3359fa0cc6d6b376d9539582c7b4220f041a33ec24c226199" +dependencies = [ + "async-trait", + "bytes", + "futures-util", + "http", + "http-body", + "http-body-util", + "mime", + "pin-project-lite", + "rustversion", + "sync_wrapper 1.0.2", + "tower-layer", + "tower-service", +] + [[package]] name = "backtrace" version = "0.3.74" @@ -1846,6 +1921,25 @@ dependencies = [ "regex-syntax 0.8.5", ] +[[package]] +name = "h2" +version = "0.4.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ccae279728d634d083c00f6099cb58f01cc99c145b84b8be2f6c74618d79922e" +dependencies = [ + "atomic-waker", + "bytes", + "fnv", + "futures-core", + "futures-sink", + "http", + "indexmap 2.7.0", + "slab", + "tokio", + "tokio-util", + "tracing", +] + [[package]] name = "half" version = "2.4.1" @@ -2021,6 +2115,94 @@ dependencies = [ "itoa", ] +[[package]] +name = "http-body" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184" +dependencies = [ + "bytes", + "http", +] + +[[package]] +name = "http-body-util" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "793429d76616a256bcb62c2a2ec2bed781c8307e797e2598c50010f2bee2544f" +dependencies = [ + "bytes", + "futures-util", + "http", + "http-body", + "pin-project-lite", +] + +[[package]] +name = "httparse" +version = "1.9.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7d71d3574edd2771538b901e6549113b4006ece66150fb69c0fb6d9a2adae946" + +[[package]] +name = "httpdate" +version = "1.0.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" + +[[package]] +name = "hyper" +version = "1.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "97818827ef4f364230e16705d4706e2897df2bb60617d6ca15d598025a3c481f" +dependencies = [ + "bytes", + "futures-channel", + "futures-util", + "h2", + "http", + "http-body", + "httparse", + "httpdate", + "itoa", + "pin-project-lite", + "smallvec", + "tokio", + "want", +] + +[[package]] +name = "hyper-timeout" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b90d566bffbce6a75bd8b09a05aa8c2cb1fabb6cb348f8840c9e4c90a0d83b0" +dependencies = [ + "hyper", + "hyper-util", + "pin-project-lite", + "tokio", + "tower-service", +] + +[[package]] +name = "hyper-util" +version = "0.1.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "df2dcfbe0677734ab2f3ffa7fa7bfd4706bfdc1ef393f2ee30184aed67e631b4" +dependencies = [ + "bytes", + "futures-channel", + "futures-util", + "http", + "http-body", + "hyper", + "pin-project-lite", + "socket2", + "tokio", + "tower-service", + "tracing", +] + [[package]] name = "iana-time-zone" version = "0.1.61" @@ -2671,6 +2853,12 @@ version = "0.1.10" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2532096657941c2fea9c289d370a250971c689d4f143798ff67113ec042024a5" +[[package]] +name = "matchit" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0e7465ac9959cc2b1404e8e2367b43684a6d13790fe23056cc8c6c5a6b7bcb94" + [[package]] name = "md4" version = "0.10.2" @@ -3046,6 +3234,71 @@ version = "11.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b410bbe7e14ab526a0e86877eb47c6996a2bd7746f027ba551028c925390e4e9" +[[package]] +name = "opentelemetry" +version = "0.26.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "570074cc999d1a58184080966e5bd3bf3a9a4af650c3b05047c2621e7405cd17" +dependencies = [ + "futures-core", + "futures-sink", + "js-sys", + "once_cell", + "pin-project-lite", + "thiserror 1.0.69", +] + +[[package]] +name = "opentelemetry-otlp" +version = "0.26.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "29e1f9c8b032d4f635c730c0efcf731d5e2530ea13fa8bef7939ddc8420696bd" +dependencies = [ + "async-trait", + "futures-core", + "http", + "opentelemetry", + "opentelemetry-proto", + "opentelemetry_sdk", + "prost", + "thiserror 1.0.69", + "tokio", + "tonic", +] + +[[package]] +name = "opentelemetry-proto" +version = "0.26.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c9d3968ce3aefdcca5c27e3c4ea4391b37547726a70893aab52d3de95d5f8b34" +dependencies = [ + "opentelemetry", + "opentelemetry_sdk", + "prost", + "tonic", +] + +[[package]] +name = "opentelemetry_sdk" +version = "0.26.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d2c627d9f4c9cdc1f21a29ee4bfbd6028fcb8bcf2a857b43f3abdf72c9c862f3" +dependencies = [ + "async-trait", + "futures-channel", + "futures-executor", + "futures-util", + "glob", + "once_cell", + "opentelemetry", + "percent-encoding", + "rand", + "serde_json", + "thiserror 1.0.69", + "tokio", + "tokio-stream", +] + [[package]] name = "outref" version = "0.1.0" @@ -3456,6 +3709,29 @@ dependencies = [ "unicode-ident", ] +[[package]] +name = "prost" +version = "0.13.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2c0fef6c4230e4ccf618a35c59d7ede15dea37de8427500f50aff708806e42ec" +dependencies = [ + "bytes", + "prost-derive", +] + +[[package]] +name = "prost-derive" +version = "0.13.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "157c5a9d7ea5c2ed2d9fb8f495b64759f7816c7eaea54ba3978f0d63000162e3" +dependencies = [ + "anyhow", + "itertools 0.10.5", + "proc-macro2", + "quote", + "syn 2.0.95", +] + [[package]] name = "psm" version = "0.1.24" @@ -3952,6 +4228,7 @@ dependencies = [ "rspack_plugin_web_worker_template", "rspack_plugin_worker", "rspack_regex", + "rspack_tracing", "rspack_util", "rustc-hash 2.1.0", "serde", @@ -4229,6 +4506,7 @@ dependencies = [ "rustc-hash 2.1.0", "serde_json", "tokio", + "tracing", ] [[package]] @@ -4256,6 +4534,7 @@ dependencies = [ "swc", "swc_config", "swc_core", + "tracing", "url", ] @@ -4320,6 +4599,7 @@ dependencies = [ name = "rspack_node" version = "0.2.0" dependencies = [ + "anyhow", "async-trait", "color-backtrace", "cow-utils", @@ -4343,6 +4623,7 @@ dependencies = [ "rspack_tracing", "rspack_util", "tracing", + "tracing-subscriber", ] [[package]] @@ -5089,8 +5370,12 @@ dependencies = [ name = "rspack_tracing" version = "0.2.0" dependencies = [ + "opentelemetry", + "opentelemetry-otlp", + "opentelemetry_sdk", "tracing", "tracing-chrome", + "tracing-opentelemetry", "tracing-subscriber", ] @@ -6937,6 +7222,18 @@ dependencies = [ "unicode-ident", ] +[[package]] +name = "sync_wrapper" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160" + +[[package]] +name = "sync_wrapper" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0bf256ce5efdfa370213c1dabab5935a12e49f2c58d15e9eac2870d3b4f27263" + [[package]] name = "synstructure" version = "0.13.1" @@ -7155,9 +7452,13 @@ checksum = "5cec9b21b0450273377fc97bd4c33a8acffc8c996c987a7c5b319a0083707551" dependencies = [ "backtrace", "bytes", + "libc", + "mio", "parking_lot", "pin-project-lite", + "socket2", "tokio-macros", + "windows-sys 0.52.0", ] [[package]] @@ -7241,6 +7542,82 @@ dependencies = [ "winnow 0.6.20", ] +[[package]] +name = "tonic" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "877c5b330756d856ffcc4553ab34a5684481ade925ecc54bcd1bf02b1d0d4d52" +dependencies = [ + "async-stream", + "async-trait", + "axum", + "base64 0.22.1", + "bytes", + "h2", + "http", + "http-body", + "http-body-util", + "hyper", + "hyper-timeout", + "hyper-util", + "percent-encoding", + "pin-project", + "prost", + "socket2", + "tokio", + "tokio-stream", + "tower 0.4.13", + "tower-layer", + "tower-service", + "tracing", +] + +[[package]] +name = "tower" +version = "0.4.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b8fa9be0de6cf49e536ce1851f987bd21a43b771b09473c3549a6c853db37c1c" +dependencies = [ + "futures-core", + "futures-util", + "indexmap 1.9.3", + "pin-project", + "pin-project-lite", + "rand", + "slab", + "tokio", + "tokio-util", + "tower-layer", + "tower-service", + "tracing", +] + +[[package]] +name = "tower" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2873938d487c3cfb9aed7546dc9f2711d867c9f90c46b889989a2cb84eba6b4f" +dependencies = [ + "futures-core", + "futures-util", + "pin-project-lite", + "sync_wrapper 0.1.2", + "tower-layer", + "tower-service", +] + +[[package]] +name = "tower-layer" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "121c2a6cda46980bb0fcd1647ffaf6cd3fc79a013de288782836f6df9c48780e" + +[[package]] +name = "tower-service" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3" + [[package]] name = "tracing" version = "0.1.41" @@ -7296,6 +7673,24 @@ dependencies = [ "tracing-core", ] +[[package]] +name = "tracing-opentelemetry" +version = "0.27.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc58af5d3f6c5811462cabb3289aec0093f7338e367e5a33d28c0433b3c7360b" +dependencies = [ + "js-sys", + "once_cell", + "opentelemetry", + "opentelemetry_sdk", + "smallvec", + "tracing", + "tracing-core", + "tracing-log", + "tracing-subscriber", + "web-time", +] + [[package]] name = "tracing-subscriber" version = "0.3.19" @@ -7324,6 +7719,12 @@ dependencies = [ "stable_deref_trait", ] +[[package]] +name = "try-lock" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b" + [[package]] name = "trybuild" version = "1.0.101" @@ -7723,6 +8124,15 @@ dependencies = [ "winapi-util", ] +[[package]] +name = "want" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e" +dependencies = [ + "try-lock", +] + [[package]] name = "wasi" version = "0.11.0+wasi-snapshot-preview1" diff --git a/Cargo.toml b/Cargo.toml index a427a59968ad..d9a4fd4d55f7 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -85,7 +85,7 @@ ustr = { package = "ustr-fxhash", version = "1.0.1" } xxhash-rust = { version = "0.8.14" } # Pinned -napi = { version = "3.0.0-alpha.24" } +napi = { version = "3.0.0-alpha.24", features = ["anyhow"] } napi-build = { version = "2.1.4" } napi-derive = { version = "3.0.0-alpha.22" } diff --git a/crates/node_binding/Cargo.toml b/crates/node_binding/Cargo.toml index 90e99cf6e954..8f22cf09c42b 100644 --- a/crates/node_binding/Cargo.toml +++ b/crates/node_binding/Cargo.toml @@ -13,6 +13,7 @@ crate-type = ["cdylib"] plugin = ["rspack_binding_values/plugin"] [dependencies] +anyhow = { workspace = true } ropey = { workspace = true } rspack_allocator = { workspace = true } rspack_binding_values = { workspace = true } @@ -31,9 +32,10 @@ rspack_util = { workspace = true } rspack_tracing = { workspace = true } -async-trait = { workspace = true } -cow-utils = { workspace = true } -tracing = { workspace = true } +async-trait = { workspace = true } +cow-utils = { workspace = true } +tracing = { workspace = true } +tracing-subscriber = { workspace = true } napi = { workspace = true } napi-derive = { workspace = true } diff --git a/crates/node_binding/binding.d.ts b/crates/node_binding/binding.d.ts index 63dbb845231c..dee43e5da8ad 100644 --- a/crates/node_binding/binding.d.ts +++ b/crates/node_binding/binding.d.ts @@ -738,6 +738,7 @@ export interface JsLoaderContext { loaderIndex: number loaderState: Readonly __internal__error?: JsRspackError + __internal__tracingCarrier?: Record } export interface JsLoaderItem { @@ -2050,7 +2051,7 @@ export interface RawTrustedTypes { * Author Donny/강동윤 * Copyright (c) */ -export declare function registerGlobalTrace(filter: string, layer: "chrome" | "logger", output: string): void +export declare function registerGlobalTrace(filter: string, layer: "chrome" | "logger" | "otel", output: string): void export declare enum RegisterJsTapKind { CompilerThisCompilation = 0, diff --git a/crates/node_binding/src/lib.rs b/crates/node_binding/src/lib.rs index fb4a81931df5..4bed566b0709 100644 --- a/crates/node_binding/src/lib.rs +++ b/crates/node_binding/src/lib.rs @@ -5,8 +5,8 @@ extern crate napi_derive; extern crate rspack_allocator; -use std::pin::Pin; use std::sync::{Arc, Mutex}; +use std::{pin::Pin, str::FromStr as _}; use compiler::{Compiler, CompilerState, CompilerStateGuard}; use napi::bindgen_prelude::*; @@ -14,6 +14,7 @@ use rspack_core::{Compilation, PluginExt}; use rspack_error::Diagnostic; use rspack_fs::IntermediateFileSystem; use rspack_fs_node::{NodeFileSystem, ThreadsafeNodeFS}; +use rspack_napi::napi::bindgen_prelude::within_runtime_if_available; mod compiler; mod diagnostic; @@ -25,7 +26,10 @@ pub use diagnostic::*; use plugins::*; use resolver_factory::*; use rspack_binding_values::*; -use rspack_tracing::chrome::FlushGuard; +use rspack_tracing::{ChromeTracer, OtelTracer, StdoutTracer, Tracer}; +use tracing::Level; +use tracing_subscriber::EnvFilter; +use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt as _, Layer, Registry}; #[napi] pub struct Rspack { @@ -216,7 +220,7 @@ fn concurrent_compiler_error() -> Error { #[derive(Default)] enum TraceState { - On(Option), + On(Box), #[default] Off, } @@ -232,7 +236,9 @@ fn print_error_diagnostic(e: rspack_error::Error, colored: bool) -> String { .expect("should print diagnostics") } -static GLOBAL_TRACE_STATE: Mutex = Mutex::new(TraceState::Off); +thread_local! { + static GLOBAL_TRACE_STATE: Mutex = const { Mutex::new(TraceState::Off) }; +} /** * Some code is modified based on @@ -244,37 +250,60 @@ static GLOBAL_TRACE_STATE: Mutex = Mutex::new(TraceState::Off); #[napi] pub fn register_global_trace( filter: String, - #[napi(ts_arg_type = "\"chrome\" | \"logger\"")] layer: String, + #[napi(ts_arg_type = "\"chrome\" | \"logger\" | \"otel\"")] layer: String, output: String, -) { - let mut state = GLOBAL_TRACE_STATE - .lock() - .expect("Failed to lock GLOBAL_TRACE_STATE"); - if matches!(&*state, TraceState::Off) { - let guard = match layer.as_str() { - "chrome" => rspack_tracing::enable_tracing_by_env_with_chrome_layer(&filter, &output), - "logger" => { - rspack_tracing::enable_tracing_by_env(&filter, &output); - None +) -> anyhow::Result<()> { + GLOBAL_TRACE_STATE.with(|state| { + let mut state = state.lock().expect("Failed to lock GLOBAL_TRACE_STATE"); + if let TraceState::Off = *state { + let mut tracer: Box = match layer.as_str() { + "chrome" => Box::new(ChromeTracer::default()), + "otel" => Box::new(within_runtime_if_available(OtelTracer::default)), + "logger" => Box::new(StdoutTracer), + _ => anyhow::bail!( + "Unexpected layer: {}, supported layers: 'chrome', 'logger', 'console' and 'otel' ", + layer + ), + }; + if let Some(layer) = tracer.setup(&output) { + if let Ok(default_level) = Level::from_str(&filter) { + let filter = tracing_subscriber::filter::Targets::new() + .with_target("rspack_core", default_level) + .with_target("node_binding", default_level) + .with_target("rspack_loader_swc", default_level) + .with_target("rspack_loader_runner", default_level) + .with_target("rspack_plugin_javascript", default_level) + .with_target("rspack_resolver", Level::WARN); + tracing_subscriber::registry() + .with(<_ as Layer>::with_filter(layer, filter)) + .init(); + } else { + // SAFETY: we know that trace_var is `Ok(String)` now, + // for the second unwrap, if we can't parse the directive, then the tracing result would be + // unexpected, then panic is reasonable + let filter = EnvFilter::builder() + .with_regex(true) + .parse(filter) + .expect("Parse tracing directive syntax failed, for details about the directive syntax you could refer https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives"); + tracing_subscriber::registry() + .with(<_ as Layer>::with_filter(layer, filter)) + .init(); + } } - _ => panic!("not supported layer type:{layer}"), - }; - let new_state = TraceState::On(guard); - *state = new_state; - } + let new_state = TraceState::On(tracer); + *state = new_state; + } + Ok(()) + }) } #[napi] pub fn cleanup_global_trace() { - let mut state = GLOBAL_TRACE_STATE - .lock() - .expect("Failed to lock GLOBAL_TRACE_STATE"); - if let TraceState::On(guard) = &mut *state - && let Some(g) = guard.take() - { - g.flush(); - drop(g); - let new_state = TraceState::Off; - *state = new_state; - } + GLOBAL_TRACE_STATE.with(|state| { + let mut state = state.lock().expect("Failed to lock GLOBAL_TRACE_STATE"); + if let TraceState::On(ref mut tracer) = *state { + tracer.teardown(); + } + *state = TraceState::Off; + }); } diff --git a/crates/node_binding/src/plugins/mod.rs b/crates/node_binding/src/plugins/mod.rs index 3d5a5b9a18f1..9c32dd7b8b5d 100644 --- a/crates/node_binding/src/plugins/mod.rs +++ b/crates/node_binding/src/plugins/mod.rs @@ -80,7 +80,7 @@ impl rspack_core::Plugin for JsHooksAdapterPlugin { "rspack.JsHooksAdapterPlugin" } - #[tracing::instrument(name = "js_hooks_adapter::apply", skip_all)] + // #[tracing::instrument("js_hooks_adapter::apply", skip_all)] fn apply( &self, ctx: PluginContext<&mut ApplyContext>, diff --git a/crates/rspack_binding_values/Cargo.toml b/crates/rspack_binding_values/Cargo.toml index 5e2e48e27792..6589bea6052d 100644 --- a/crates/rspack_binding_values/Cargo.toml +++ b/crates/rspack_binding_values/Cargo.toml @@ -85,3 +85,4 @@ rspack_plugin_warn_sensitive_module = { workspace = true } rspack_plugin_wasm = { workspace = true } rspack_plugin_web_worker_template = { workspace = true } rspack_plugin_worker = { workspace = true } +rspack_tracing = { workspace = true } diff --git a/crates/rspack_binding_values/src/plugins/js_loader/context.rs b/crates/rspack_binding_values/src/plugins/js_loader/context.rs index 44c629fcadbc..05b589fe094d 100644 --- a/crates/rspack_binding_values/src/plugins/js_loader/context.rs +++ b/crates/rspack_binding_values/src/plugins/js_loader/context.rs @@ -6,6 +6,8 @@ use rspack_core::{LoaderContext, RunnerContext}; use rspack_error::error; use rspack_loader_runner::{LoaderItem, State as LoaderState}; use rspack_napi::threadsafe_js_value_ref::ThreadsafeJsValueRef; +use rspack_tracing::otel::{opentelemetry::global, tracing::OpenTelemetrySpanExt as _}; +use tracing::Span; use crate::{JsModuleWrapper, JsResourceData, JsRspackError}; @@ -84,6 +86,9 @@ pub struct JsLoaderContext { pub loader_state: JsLoaderState, #[napi(js_name = "__internal__error")] pub error: Option, + + #[napi(js_name = "__internal__tracingCarrier")] + pub carrier: Option>, } impl TryFrom<&mut LoaderContext> for JsLoaderContext { @@ -94,6 +99,11 @@ impl TryFrom<&mut LoaderContext> for JsLoaderContext { ) -> std::result::Result { let module = unsafe { cx.context.module.as_ref() }; + let mut carrier = HashMap::new(); + global::get_text_map_propagator(|propagator| { + let cx = Span::current().context(); + propagator.inject_context(&cx, &mut carrier); + }); Ok(JsLoaderContext { resource_data: cx.resource_data.as_ref().into(), module_identifier: module.identifier().to_string(), @@ -141,6 +151,7 @@ impl TryFrom<&mut LoaderContext> for JsLoaderContext { loader_index: cx.loader_index, loader_state: cx.state().into(), error: None, + carrier: Some(carrier), }) } } diff --git a/crates/rspack_core/src/build_chunk_graph/code_splitter.rs b/crates/rspack_core/src/build_chunk_graph/code_splitter.rs index 2e44a1edca9a..195ad8192541 100644 --- a/crates/rspack_core/src/build_chunk_graph/code_splitter.rs +++ b/crates/rspack_core/src/build_chunk_graph/code_splitter.rs @@ -747,7 +747,7 @@ Or do you want to use the entrypoints '{name}' and '{runtime}' independently on Ok(()) } - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub fn split(&mut self, compilation: &mut Compilation) -> Result<()> { let logger = compilation.get_logger("rspack.buildChunkGraph"); diff --git a/crates/rspack_core/src/build_chunk_graph/mod.rs b/crates/rspack_core/src/build_chunk_graph/mod.rs index ad4a2d236810..8850a5e10a2a 100644 --- a/crates/rspack_core/src/build_chunk_graph/mod.rs +++ b/crates/rspack_core/src/build_chunk_graph/mod.rs @@ -8,7 +8,7 @@ use crate::{incremental::IncrementalPasses, Compilation}; pub(crate) mod code_splitter; pub(crate) mod incremental; -#[instrument(skip_all)] +#[instrument("Compilation:build_chunk_graph", skip_all)] pub(crate) fn build_chunk_graph(compilation: &mut Compilation) -> rspack_error::Result<()> { let enable_incremental = compilation .incremental diff --git a/crates/rspack_core/src/chunk_graph/chunk_graph_module.rs b/crates/rspack_core/src/chunk_graph/chunk_graph_module.rs index 5b16f836b8c7..9c09a8b74693 100644 --- a/crates/rspack_core/src/chunk_graph/chunk_graph_module.rs +++ b/crates/rspack_core/src/chunk_graph/chunk_graph_module.rs @@ -255,7 +255,7 @@ impl ChunkGraph { .set_hashes(module_identifier, hashes); } - #[instrument(name = "chunk_graph:get_module_graph_hash", skip_all, fields(module = ?module.identifier()))] + #[instrument("chunk_graph:get_module_graph_hash", skip_all, fields(module = ?module.identifier()))] pub fn get_module_graph_hash( &self, module: &dyn Module, diff --git a/crates/rspack_core/src/compiler/compilation.rs b/crates/rspack_core/src/compiler/compilation.rs index 3957368dd2d6..4a52a29f546d 100644 --- a/crates/rspack_core/src/compiler/compilation.rs +++ b/crates/rspack_core/src/compiler/compilation.rs @@ -28,7 +28,7 @@ use rspack_paths::ArcPath; use rspack_sources::{BoxSource, CachedSource, SourceExt}; use rspack_util::itoa; use rustc_hash::{FxHashMap as HashMap, FxHashSet as HashSet, FxHasher}; -use tracing::instrument; +use tracing::{info_span, instrument, Instrument}; use super::{ hmr::CompilationRecords, @@ -813,7 +813,7 @@ impl Compilation { ukey } - #[instrument(name = "compilation:make", skip_all)] + #[instrument("Compilation:make", skip_all)] pub async fn make(&mut self) -> Result<()> { self.make_artifact.reset_dependencies_incremental_info(); // self.module_executor. @@ -852,7 +852,7 @@ impl Compilation { .collect::>())) } - #[instrument(name = "compilation:code_generation", skip_all)] + #[instrument("Compilation:code_generation", skip_all)] fn code_generation(&mut self, modules: IdentifierSet) -> Result<()> { let logger = self.get_logger("rspack.Compilation"); let mut codegen_cache_counter = match self.options.cache { @@ -990,7 +990,7 @@ impl Compilation { Ok(()) } - #[instrument(name = "compilation::create_module_assets", skip_all)] + #[instrument("Compilation:create_module_assets", skip_all)] async fn create_module_assets(&mut self, _plugin_driver: SharedPluginDriver) { let mut temp = vec![]; for (module_identifier, assets) in self.module_assets.iter() { @@ -1018,7 +1018,7 @@ impl Compilation { } } - #[instrument(skip_all)] + #[instrument("Compilation::create_chunk_assets", skip_all)] async fn create_chunk_assets(&mut self, plugin_driver: SharedPluginDriver) -> Result<()> { let mutations = self .incremental @@ -1118,7 +1118,16 @@ impl Compilation { Ok(()) } - #[instrument(name = "compilation:after_process_asssets", skip_all)] + #[instrument("Compilation:process_assets", skip_all)] + async fn process_assets(&mut self, plugin_driver: SharedPluginDriver) -> Result<()> { + plugin_driver + .compilation_hooks + .process_assets + .call(self) + .await + } + + #[instrument("Compilation:after_process_asssets", skip_all)] async fn after_process_assets(&mut self, plugin_driver: SharedPluginDriver) -> Result<()> { plugin_driver .compilation_hooks @@ -1127,15 +1136,15 @@ impl Compilation { .await } - #[instrument(name = "compilation:after_seal", skip_all)] + #[instrument("Compilation:after_seal", skip_all)] async fn after_seal(&mut self, plugin_driver: SharedPluginDriver) -> Result<()> { plugin_driver.compilation_hooks.after_seal.call(self).await } - #[instrument( - name = "compilation:chunk_asset", - skip(self, plugin_driver, chunk_ukey) - )] + // #[instrument( + // name = "Compilation:chunk_asset", + // skip(self, plugin_driver, chunk_ukey) + // )] async fn chunk_asset( &self, chunk_ukey: ChunkUkey, @@ -1172,7 +1181,7 @@ impl Compilation { self.chunk_group_by_ukey.expect_get(ukey) } - #[instrument(name = "compilation:finish", skip_all)] + #[instrument("Compilation:finish", skip_all)] pub async fn finish(&mut self, plugin_driver: SharedPluginDriver) -> Result<()> { let logger = self.get_logger("rspack.Compilation"); @@ -1228,7 +1237,7 @@ impl Compilation { Ok(()) } - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] fn collect_dependencies_diagnostics(&mut self) { let mutations = self .incremental @@ -1285,7 +1294,7 @@ impl Compilation { self.extend_diagnostics(all_modules_diagnostics.into_values().flatten()); } - #[instrument(name = "compilation:seal", skip_all)] + #[instrument("Compilation:seal", skip_all)] pub async fn seal(&mut self, plugin_driver: SharedPluginDriver) -> Result<()> { self.other_module_graph = Some(ModuleGraphPartial::default()); let logger = self.get_logger("rspack.Compilation"); @@ -1319,6 +1328,7 @@ impl Compilation { .compilation_hooks .optimize_modules .call(self) + .instrument(info_span!("Compilation:optimize_modules")) .await?, Some(true) ) {} @@ -1326,12 +1336,12 @@ impl Compilation { .compilation_hooks .after_optimize_modules .call(self) + .instrument(info_span!("Compilation:after_optimize_modules")) .await?; while matches!( plugin_driver.compilation_hooks.optimize_chunks.call(self)?, Some(true) ) {} - logger.time_end(start); let start = logger.time("optimize"); @@ -1339,12 +1349,14 @@ impl Compilation { .compilation_hooks .optimize_tree .call(self) + .instrument(info_span!("Compilation:optimize_tree")) .await?; plugin_driver .compilation_hooks .optimize_chunk_modules .call(self) + .instrument(info_span!("Compilation:optimize_chunk_modules")) .await?; logger.time_end(start); @@ -1352,12 +1364,13 @@ impl Compilation { // so now we can start to generate assets based on the chunk graph let start = logger.time("module ids"); - plugin_driver.compilation_hooks.module_ids.call(self)?; + tracing::info_span!("Compilation:module_ids") + .in_scope(|| plugin_driver.compilation_hooks.module_ids.call(self))?; logger.time_end(start); let start = logger.time("chunk ids"); - plugin_driver.compilation_hooks.chunk_ids.call(self)?; - + tracing::info_span!("Compilation:chunk_ids") + .in_scope(|| plugin_driver.compilation_hooks.chunk_ids.call(self))?; logger.time_end(start); self.assign_runtime_ids(); @@ -1388,10 +1401,12 @@ impl Compilation { self.create_module_hashes(create_module_hashes_modules)?; let start = logger.time("optimize code generation"); - plugin_driver - .compilation_hooks - .optimize_code_generation - .call(self)?; + tracing::info_span!("Compilation::optimize_code_generation").in_scope(|| { + plugin_driver + .compilation_hooks + .optimize_code_generation + .call(self) + })?; logger.time_end(start); let start = logger.time("code generation"); @@ -1539,11 +1554,7 @@ impl Compilation { logger.time_end(start); let start = logger.time("process assets"); - plugin_driver - .compilation_hooks - .process_assets - .call(self) - .await?; + self.process_assets(plugin_driver.clone()).await?; logger.time_end(start); let start = logger.time("after process assets"); @@ -1613,7 +1624,7 @@ impl Compilation { entries.chain(async_entries) } - #[instrument(skip_all)] + #[instrument("Compilation:process_modules_runtime_requirements", skip_all)] pub async fn process_modules_runtime_requirements( &mut self, modules: IdentifierSet, @@ -1673,7 +1684,7 @@ impl Compilation { Ok(()) } - #[instrument(skip_all)] + #[instrument(name = "Compilation:process_chunks_runtime_requirements", skip_all)] pub async fn process_chunks_runtime_requirements( &mut self, chunks: UkeySet, @@ -1785,7 +1796,7 @@ impl Compilation { Ok(()) } - #[instrument(name = "compilation:create_hash", skip_all)] + #[instrument(name = "Compilation:create_hash", skip_all)] pub async fn create_hash( &mut self, create_hash_chunks: UkeySet, @@ -2084,7 +2095,7 @@ impl Compilation { Ok((chunk_hash, content_hashes)) } - #[instrument(name = "compilation:create_module_hashes", skip_all)] + #[instrument("Compilation:create_module_hashes", skip_all)] pub fn create_module_hashes(&mut self, modules: IdentifierSet) -> Result<()> { let mg = self.get_module_graph(); let results: Vec<(ModuleIdentifier, RuntimeSpecMap)> = modules diff --git a/crates/rspack_core/src/compiler/hmr.rs b/crates/rspack_core/src/compiler/hmr.rs index 80d47decfc5d..2b8d1096ac69 100644 --- a/crates/rspack_core/src/compiler/hmr.rs +++ b/crates/rspack_core/src/compiler/hmr.rs @@ -15,6 +15,10 @@ use crate::{ }; impl Compiler { + #[tracing::instrument("Compiler:rebuild", skip_all, fields( + compiler.changed_files = ?changed_files.iter().cloned().collect::>(), + compiler.deleted_files = ?deleted_files.iter().cloned().collect::>() + ))] pub async fn rebuild( &mut self, changed_files: std::collections::HashSet, diff --git a/crates/rspack_core/src/compiler/mod.rs b/crates/rspack_core/src/compiler/mod.rs index fafc0874db61..b9bf17e798f1 100644 --- a/crates/rspack_core/src/compiler/mod.rs +++ b/crates/rspack_core/src/compiler/mod.rs @@ -163,7 +163,7 @@ impl Compiler { Ok(()) } - #[instrument(name = "build", skip_all)] + #[instrument("Compiler:build", skip_all)] pub async fn build(&mut self) -> Result<()> { self.old_cache.end_idle(); // TODO: clear the outdated cache entries in resolver, @@ -202,7 +202,7 @@ impl Compiler { Ok(()) } - #[instrument(name = "compile", skip_all)] + #[instrument("Compiler:compile", skip_all)] async fn compile(&mut self) -> Result<()> { let mut compilation_params = self.new_compilation_params(); // FOR BINDING SAFETY: @@ -275,7 +275,7 @@ impl Compiler { Ok(()) } - #[instrument(name = "compile_done", skip_all)] + #[instrument("Compile:done", skip_all)] async fn compile_done(&mut self) -> Result<()> { let logger = self.compilation.get_logger("rspack.Compiler"); @@ -298,7 +298,7 @@ impl Compiler { Ok(()) } - #[instrument(name = "emit_assets", skip_all)] + #[instrument("emit_assets", skip_all)] pub async fn emit_assets(&mut self) -> Result<()> { self.run_clean_options().await?; diff --git a/crates/rspack_core/src/concatenated_module.rs b/crates/rspack_core/src/concatenated_module.rs index 4b87057d9690..9764506fbe94 100644 --- a/crates/rspack_core/src/concatenated_module.rs +++ b/crates/rspack_core/src/concatenated_module.rs @@ -617,7 +617,7 @@ impl Module for ConcatenatedModule { Ok(BuildResult::default()) } - #[tracing::instrument(name = "ConcatenatedModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ConcatenatedModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_core/src/context_module.rs b/crates/rspack_core/src/context_module.rs index f9ac2b724c31..03d9dde13021 100644 --- a/crates/rspack_core/src/context_module.rs +++ b/crates/rspack_core/src/context_module.rs @@ -989,7 +989,7 @@ impl Module for ContextModule { }) } - #[tracing::instrument(name = "ContextModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ContextModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_core/src/context_module_factory.rs b/crates/rspack_core/src/context_module_factory.rs index d0f4324f6ee5..61c00bcabad6 100644 --- a/crates/rspack_core/src/context_module_factory.rs +++ b/crates/rspack_core/src/context_module_factory.rs @@ -94,7 +94,7 @@ pub struct ContextModuleFactory { #[async_trait::async_trait] impl ModuleFactory for ContextModuleFactory { - #[instrument(name = "context_module_factory:create", skip_all)] + #[instrument("context_module_factory:create", skip_all)] async fn create(&self, data: &mut ModuleFactoryCreateData) -> Result { match self.before_resolve(data).await? { BeforeResolveResult::Ignored => return Ok(ModuleFactoryResult::default()), diff --git a/crates/rspack_core/src/external_module.rs b/crates/rspack_core/src/external_module.rs index 669e907ecf02..faf30f118bc6 100644 --- a/crates/rspack_core/src/external_module.rs +++ b/crates/rspack_core/src/external_module.rs @@ -567,7 +567,7 @@ impl Module for ExternalModule { Ok(build_result) } - #[tracing::instrument(name = "ExternalModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ExternalModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_core/src/module_graph/mod.rs b/crates/rspack_core/src/module_graph/mod.rs index 1fb2e6d4d5f9..58abd509e067 100644 --- a/crates/rspack_core/src/module_graph/mod.rs +++ b/crates/rspack_core/src/module_graph/mod.rs @@ -184,7 +184,7 @@ impl<'a> ModuleGraph<'a> { res } - #[tracing::instrument(skip_all, fields(module = ?module_id))] + // #[tracing::instrument(skip_all, fields(module = ?module_id))] pub fn get_incoming_connections_by_origin_module( &self, module_id: &ModuleIdentifier, diff --git a/crates/rspack_core/src/normal_module.rs b/crates/rspack_core/src/normal_module.rs index 7a5abee550ca..c1c9ad8347f1 100644 --- a/crates/rspack_core/src/normal_module.rs +++ b/crates/rspack_core/src/normal_module.rs @@ -312,6 +312,7 @@ impl NormalModule { &mut self.presentational_dependencies } + #[tracing::instrument("NormalModule:build_hash")] fn init_build_hash( &self, output_options: &OutputOptions, @@ -399,6 +400,11 @@ impl Module for NormalModule { } } + #[tracing::instrument("NormalModule:build", skip_all, fields( + module.resource = self.resource_resolved_data().resource.as_str(), + module.identifier = self.identifier().as_str(), + module.loaders = ?self.loaders.iter().map(|l| l.identifier().as_str()).collect::>()) + )] async fn build( &mut self, build_context: BuildContext, @@ -626,7 +632,7 @@ impl Module for NormalModule { }) } - #[tracing::instrument(name = "NormalModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("NormalModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_core/src/normal_module_factory.rs b/crates/rspack_core/src/normal_module_factory.rs index e60d237eb71d..4b794cc84c81 100644 --- a/crates/rspack_core/src/normal_module_factory.rs +++ b/crates/rspack_core/src/normal_module_factory.rs @@ -511,7 +511,6 @@ impl NormalModuleFactory { } else { resource_data.resource.clone() }; - tracing::trace!("resolved uri {:?}", request); let file_dependency = resource_data.resource_path.clone(); diff --git a/crates/rspack_core/src/old_cache/occasion/code_generate.rs b/crates/rspack_core/src/old_cache/occasion/code_generate.rs index a29751506efc..f8f1225180cc 100644 --- a/crates/rspack_core/src/old_cache/occasion/code_generate.rs +++ b/crates/rspack_core/src/old_cache/occasion/code_generate.rs @@ -16,7 +16,7 @@ impl CodeGenerateOccasion { Self { storage } } - #[tracing::instrument(skip_all, fields(module = ?job.module))] + // #[tracing::instrument(skip_all, fields(module = ?job.module))] pub fn use_cache( &self, job: CodeGenerationJob, diff --git a/crates/rspack_core/src/old_cache/occasion/process_runtime_requirements.rs b/crates/rspack_core/src/old_cache/occasion/process_runtime_requirements.rs index b8f2a4017098..1d9a71f7c151 100644 --- a/crates/rspack_core/src/old_cache/occasion/process_runtime_requirements.rs +++ b/crates/rspack_core/src/old_cache/occasion/process_runtime_requirements.rs @@ -18,7 +18,7 @@ impl ProcessRuntimeRequirementsOccasion { Self { storage } } - #[tracing::instrument(skip_all, fields(module = ?module))] + // #[tracing::instrument(skip_all, fields(module = ?module))] pub fn use_cache( &self, module: ModuleIdentifier, diff --git a/crates/rspack_core/src/raw_module.rs b/crates/rspack_core/src/raw_module.rs index 94af6ce443e8..eccc9d42ba63 100644 --- a/crates/rspack_core/src/raw_module.rs +++ b/crates/rspack_core/src/raw_module.rs @@ -128,7 +128,7 @@ impl Module for RawModule { }) } - #[tracing::instrument(name = "RawModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("RawModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, _compilation: &crate::Compilation, diff --git a/crates/rspack_core/src/resolver/mod.rs b/crates/rspack_core/src/resolver/mod.rs index cbea1e10856d..c18b8c6773de 100644 --- a/crates/rspack_core/src/resolver/mod.rs +++ b/crates/rspack_core/src/resolver/mod.rs @@ -282,6 +282,15 @@ if its extension was not listed in the `resolve.extensions`. Here're some possib } /// Main entry point for module resolution. +// #[tracing::instrument(err, "resolve", skip_all, fields( +// resolve.specifier = args.specifier, +// resolve.importer = ?args.importer, +// resolve.context = ?args.context, +// resolve.dependency_type = ?args.dependency_type, +// resolve.dependency_category = ?args.dependency_category +// ), +// level = "trace" +// )] pub async fn resolve( args: ResolveArgs<'_>, plugin_driver: &SharedPluginDriver, @@ -301,6 +310,18 @@ pub async fn resolve( .resolve_with_context(args.context.as_ref(), args.specifier, &mut context) .map_err(|error| error.into_resolve_error(&args)); + if let Err(ref err) = result { + tracing::error!( + specifier = args.specifier, + importer = ?args.importer, + context = %args.context, + dependency_type = %args.dependency_type, + dependency_category = %args.dependency_category, + "Resolve error: {}", + err.to_string() + ); + } + args.file_dependencies.extend(context.file_dependencies); args .missing_dependencies diff --git a/crates/rspack_core/src/self_module.rs b/crates/rspack_core/src/self_module.rs index acf8f266c0e3..6df44aa56b7f 100644 --- a/crates/rspack_core/src/self_module.rs +++ b/crates/rspack_core/src/self_module.rs @@ -128,7 +128,7 @@ impl Module for SelfModule { }) } - #[tracing::instrument(name = "SelfModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("SelfModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, _compilation: &Compilation, diff --git a/crates/rspack_core/src/unaffected_cache/mod.rs b/crates/rspack_core/src/unaffected_cache/mod.rs new file mode 100644 index 000000000000..61ba2b287645 --- /dev/null +++ b/crates/rspack_core/src/unaffected_cache/mod.rs @@ -0,0 +1,370 @@ +mod mutations; + +use std::{ + hash::{BuildHasherDefault, Hash, Hasher}, + sync::Mutex, +}; + +pub use mutations::{Mutation, Mutations}; +use rayon::iter::{IntoParallelIterator, IntoParallelRefIterator, ParallelIterator}; +use rspack_collections::{IdentifierDashMap, IdentifierHasher, IdentifierMap, IdentifierSet}; +use rspack_util::fx_hash::FxIndexSet; +use rustc_hash::FxHasher; + +use crate::{ + AffectType, ChunkGraph, Compilation, Module, ModuleGraph, ModuleGraphConnection, ModuleIdentifier, +}; + +#[derive(Debug, Default)] +pub struct UnaffectedModulesCache { + module_to_cache: IdentifierDashMap, + affected_modules_with_module_graph: Mutex, + affected_modules_with_chunk_graph: Mutex, +} + +#[derive(Debug)] +struct UnaffectedModuleCache { + module_graph_invalidate_key: u64, + with_chunk_graph_cache: Option, +} + +#[derive(Debug)] +struct UnaffectedModuleWithChunkGraphCache { + chunk_graph_invalidate_key: u64, +} + +impl UnaffectedModulesCache { + fn par_iter( + &self, + ) -> dashmap::rayon::map::Iter< + ModuleIdentifier, + UnaffectedModuleCache, + BuildHasherDefault, + > { + self.module_to_cache.par_iter() + } + + // #[tracing::instrument(skip_all, fields(module = ?key))] + fn remove_cache(&self, key: &ModuleIdentifier) { + self.module_to_cache.remove(key); + } + + // #[tracing::instrument(skip_all, fields(module = ?key))] + fn insert_cache(&self, key: ModuleIdentifier, value: UnaffectedModuleCache) { + self.module_to_cache.insert(key, value); + } + + // #[tracing::instrument(skip_all, fields(module = ?key))] + fn affect_cache(&self, key: &ModuleIdentifier) -> Option<()> { + let mut cache = self.module_to_cache.get_mut(key)?; + cache.with_chunk_graph_cache = None; + // remove other cache... + Some(()) + } + + // #[tracing::instrument(skip_all, fields(module = ?key))] + fn insert_chunk_graph_cache( + &self, + key: &ModuleIdentifier, + value: UnaffectedModuleWithChunkGraphCache, + ) -> Option<()> { + let mut cache = self.module_to_cache.get_mut(key)?; + cache.with_chunk_graph_cache = Some(value); + Some(()) + } + + // #[tracing::instrument(skip_all)] + pub fn compute_affected_modules_with_module_graph(&self, compilation: &Compilation) { + let mg = compilation.get_module_graph(); + let modules = mg.modules().keys().copied().collect(); + let mut affected_modules = self + .affected_modules_with_module_graph + .lock() + .expect("failed to lock"); + *affected_modules = compute_affected_modules_with_module_graph(compilation, modules); + } + + // #[tracing::instrument(skip_all)] + pub fn get_affected_modules_with_module_graph(&self) -> &Mutex { + &self.affected_modules_with_module_graph + } + + // #[tracing::instrument(skip_all)] + pub fn compute_affected_modules_with_chunk_graph(&self, compilation: &Compilation) { + let mut affected_modules = self + .affected_modules_with_chunk_graph + .lock() + .expect("failed to lock"); + *affected_modules = compute_affected_modules_with_chunk_graph(compilation); + } + + // #[tracing::instrument(skip_all)] + pub fn get_affected_modules_with_chunk_graph(&self) -> &Mutex { + &self.affected_modules_with_chunk_graph + } +} + +impl UnaffectedModuleCache { + fn new(module_graph_invalidate_key: u64) -> Self { + Self { + module_graph_invalidate_key, + with_chunk_graph_cache: None, + } + } + + // #[tracing::instrument(skip_all, fields(module = ?module.identifier()))] + fn create_module_graph_invalidate_key(module_graph: &ModuleGraph, module: &dyn Module) -> u64 { + let mut hasher = FxHasher::default(); + module + .build_info() + .expect("should have build_info after build") + .hash + .as_ref() + .hash(&mut hasher); + for dep_id in module_graph + .get_ordered_connections(&module.identifier()) + .expect("should have module") + { + dep_id.hash(&mut hasher); + } + hasher.finish() + } +} + +impl UnaffectedModuleWithChunkGraphCache { + // #[tracing::instrument(skip_all, fields(module = ?module.identifier()))] + fn create_chunk_graph_invalidate_key( + chunk_graph: &ChunkGraph, + module_graph: &ModuleGraph, + compilation: &Compilation, + module: &dyn Module, + ) -> u64 { + let module_identifier = module.identifier(); + let mut hasher = FxHasher::default(); + chunk_graph + .get_module_id(module_identifier) + .hash(&mut hasher); + let module_ids: FxIndexSet<_> = module_graph + .get_ordered_connections(&module_identifier) + .expect("should have module") + .into_iter() + .filter_map(|dep_id| { + let connection = module_graph + .connection_by_dependency_id(dep_id) + .expect("should have connection"); + chunk_graph.get_module_id(*connection.module_identifier()) + }) + .collect(); + for module_id in module_ids { + module_id.hash(&mut hasher); + } + for block_id in module.get_blocks() { + let Some(chunk_group) = + chunk_graph.get_block_chunk_group(block_id, &compilation.chunk_group_by_ukey) + else { + continue; + }; + for chunk in &chunk_group.chunks { + let chunk = compilation.chunk_by_ukey.expect_get(chunk); + chunk.id.as_ref().hash(&mut hasher); + } + } + hasher.finish() + } +} + +fn compute_affected_modules_with_module_graph( + compilation: &Compilation, + modules: IdentifierSet, +) -> IdentifierSet { + fn reduce_affect_type( + module_graph: &ModuleGraph, + connections: &[ModuleGraphConnection], + ) -> AffectType { + let mut affected = AffectType::False; + for connection in connections { + let Some(dependency) = module_graph.dependency_by_id(&connection.dependency_id) else { + continue; + }; + match dependency.could_affect_referencing_module() { + AffectType::True => affected = AffectType::True, + AffectType::False => continue, + AffectType::Transitive => return AffectType::Transitive, + } + } + affected + } + + enum ModulesCacheOp { + Delete(ModuleIdentifier), + Unaffected(ModuleIdentifier), + Affected(ModuleIdentifier, u64), + } + + let module_graph = compilation.get_module_graph(); + let modules_cache = compilation.unaffected_modules_cache.clone(); + let mut modules_without_cache = modules; + let results: Vec = modules_cache + .par_iter() + .map(|item| { + let (module_identifier, cache) = item.pair(); + if modules_without_cache.contains(module_identifier) { + let module = module_graph + .module_by_identifier(module_identifier) + .expect("should have module"); + let invalidate_key = + UnaffectedModuleCache::create_module_graph_invalidate_key(&module_graph, module.as_ref()); + if cache.module_graph_invalidate_key != invalidate_key { + ModulesCacheOp::Affected(*module_identifier, invalidate_key) + } else { + ModulesCacheOp::Unaffected(*module_identifier) + } + } else { + ModulesCacheOp::Delete(*module_identifier) + } + }) + .collect(); + let mut affected_modules_cache = IdentifierMap::default(); + for result in results { + match result { + ModulesCacheOp::Delete(m) => { + modules_cache.remove_cache(&m); + } + ModulesCacheOp::Unaffected(m) => { + modules_without_cache.remove(&m); + } + ModulesCacheOp::Affected(m, invalidate_key) => { + modules_without_cache.remove(&m); + affected_modules_cache.insert(m, invalidate_key); + } + } + } + let more_affected_modules: Vec<_> = modules_without_cache + .into_par_iter() + .map(|module_identifier| { + let module = module_graph + .module_by_identifier(&module_identifier) + .expect("should have module"); + let invalidate_key = + UnaffectedModuleCache::create_module_graph_invalidate_key(&module_graph, module.as_ref()); + (module_identifier, invalidate_key) + }) + .collect(); + affected_modules_cache.extend(more_affected_modules); + + enum AffectedModuleKind { + Direct(ModuleIdentifier), + Transitive(ModuleIdentifier), + } + let mut all_affected_modules: IdentifierSet = affected_modules_cache.keys().copied().collect(); + let affected_modules_cache_iter = + affected_modules_cache + .par_iter() + .flat_map(|(&module_identifier, &invalidate_key)| { + modules_cache.insert_cache( + module_identifier, + UnaffectedModuleCache::new(invalidate_key), + ); + module_graph + .get_incoming_connections_by_origin_module(&module_identifier) + .into_iter() + .filter_map(|(referencing_module, connections)| { + let referencing_module = referencing_module?; + if all_affected_modules.contains(&referencing_module) { + return None; + } + match reduce_affect_type(&module_graph, &connections) { + AffectType::False => None, + AffectType::True => { + modules_cache.affect_cache(&referencing_module); + Some(AffectedModuleKind::Direct(referencing_module)) + } + AffectType::Transitive => { + modules_cache.affect_cache(&referencing_module); + Some(AffectedModuleKind::Transitive(referencing_module)) + } + } + }) + .collect::>() + }); + let mut direct_affected_modules: IdentifierSet = affected_modules_cache_iter + .clone() + .filter_map(|k| match k { + AffectedModuleKind::Direct(m) => Some(m), + AffectedModuleKind::Transitive(_) => None, + }) + .collect(); + let mut transitive_affected_modules: IdentifierSet = affected_modules_cache_iter + .clone() + .filter_map(|k| match k { + AffectedModuleKind::Transitive(m) => Some(m), + AffectedModuleKind::Direct(_) => None, + }) + .collect(); + while !transitive_affected_modules.is_empty() { + let transitive_affected_modules_current = std::mem::take(&mut transitive_affected_modules); + all_affected_modules.extend(transitive_affected_modules_current.iter().copied()); + for &module_identifier in transitive_affected_modules_current.iter() { + for (referencing_module, connections) in + module_graph.get_incoming_connections_by_origin_module(&module_identifier) + { + let Some(referencing_module) = referencing_module else { + continue; + }; + if all_affected_modules.contains(&referencing_module) { + continue; + } + match reduce_affect_type(&module_graph, &connections) { + AffectType::False => continue, + AffectType::True => { + direct_affected_modules.insert(referencing_module); + } + AffectType::Transitive => { + transitive_affected_modules.insert(referencing_module); + } + }; + modules_cache.affect_cache(&referencing_module); + } + } + } + all_affected_modules.extend(direct_affected_modules); + all_affected_modules +} + +fn compute_affected_modules_with_chunk_graph(compilation: &Compilation) -> IdentifierSet { + let modules_cache = compilation.unaffected_modules_cache.clone(); + let module_graph = compilation.get_module_graph(); + let affected_modules: IdentifierMap = modules_cache + .par_iter() + .filter_map(|item| { + let (module_identifier, cache) = item.pair(); + let module = module_graph + .module_by_identifier(module_identifier) + .expect("should have module"); + let invalidate_key = UnaffectedModuleWithChunkGraphCache::create_chunk_graph_invalidate_key( + &compilation.chunk_graph, + &module_graph, + compilation, + module.as_ref(), + ); + if let Some(module_graph_cache) = &cache.with_chunk_graph_cache { + if module_graph_cache.chunk_graph_invalidate_key != invalidate_key { + Some((*module_identifier, invalidate_key)) + } else { + None + } + } else { + Some((*module_identifier, invalidate_key)) + } + }) + .collect(); + for (module_identifier, invalidate_key) in affected_modules.iter() { + modules_cache.insert_chunk_graph_cache( + module_identifier, + UnaffectedModuleWithChunkGraphCache { + chunk_graph_invalidate_key: *invalidate_key, + }, + ); + } + affected_modules.keys().copied().collect() +} diff --git a/crates/rspack_core/src/utils/task_loop.rs b/crates/rspack_core/src/utils/task_loop.rs index 8f8a1c901e6f..1ad13a88c042 100644 --- a/crates/rspack_core/src/utils/task_loop.rs +++ b/crates/rspack_core/src/utils/task_loop.rs @@ -14,6 +14,7 @@ use tokio::{ sync::mpsc::{self, error::TryRecvError}, task, }; +use tracing::Instrument; /// Result returned by task /// @@ -84,12 +85,15 @@ pub async fn run_task_loop_with_event( let tx = tx.clone(); let is_expected_shutdown = is_expected_shutdown.clone(); active_task_count += 1; - tokio::spawn(task::unconstrained(async move { - let r = task.background_run().await; - if !is_expected_shutdown.load(Ordering::Relaxed) { - tx.send(r).expect("failed to send task result"); + tokio::spawn(task::unconstrained( + async move { + let r = task.background_run().await; + if !is_expected_shutdown.load(Ordering::Relaxed) { + tx.send(r).expect("failed to send task result"); + } } - })); + .in_current_span(), + )); } TaskType::Sync => { // merge sync task result directly diff --git a/crates/rspack_loader_runner/Cargo.toml b/crates/rspack_loader_runner/Cargo.toml index 09012c478e89..acc321774842 100644 --- a/crates/rspack_loader_runner/Cargo.toml +++ b/crates/rspack_loader_runner/Cargo.toml @@ -22,3 +22,4 @@ rspack_paths = { workspace = true } rspack_sources = { workspace = true } rspack_util = { workspace = true } serde_json = { workspace = true } +tracing = { workspace = true } diff --git a/crates/rspack_loader_runner/src/runner.rs b/crates/rspack_loader_runner/src/runner.rs index 90e29dc28357..e6c7c832394a 100644 --- a/crates/rspack_loader_runner/src/runner.rs +++ b/crates/rspack_loader_runner/src/runner.rs @@ -25,6 +25,11 @@ impl LoaderContext { } } +// #[tracing::instrument("LoaderRunner:process_resource", +// skip_all, +// fields(module.resource = loader_context.resource_data.resource), +// level = "trace" +// )] async fn process_resource( loader_context: &mut LoaderContext, fs: Arc, @@ -103,6 +108,7 @@ async fn create_loader_context( Ok(loader_context) } +#[tracing::instrument("LoaderRunner:run_loaders", skip_all, level = "trace")] pub async fn run_loaders( loaders: Vec>>, resource_data: Arc, diff --git a/crates/rspack_loader_swc/Cargo.toml b/crates/rspack_loader_swc/Cargo.toml index 9a14e9f35a1b..8c51121860a2 100644 --- a/crates/rspack_loader_swc/Cargo.toml +++ b/crates/rspack_loader_swc/Cargo.toml @@ -37,6 +37,8 @@ stacker = { workspace = true } swc = { workspace = true, features = ["manual-tokio-runtmie"] } swc_config = { workspace = true } swc_core = { workspace = true, features = ["base", "ecma_ast", "common"] } -url = "2.5.4" +tracing = { workspace = true } +url = "2.5.0" + [build-dependencies] cargo_toml = { version = "0.21.0" } diff --git a/crates/rspack_loader_swc/src/lib.rs b/crates/rspack_loader_swc/src/lib.rs index 414467536076..ee25c0453464 100644 --- a/crates/rspack_loader_swc/src/lib.rs +++ b/crates/rspack_loader_swc/src/lib.rs @@ -141,6 +141,7 @@ pub const SWC_LOADER_IDENTIFIER: &str = "builtin:swc-loader"; #[cacheable_dyn] #[async_trait::async_trait] impl Loader for SwcLoader { + #[tracing::instrument("SwcLoader:run", skip_all)] async fn run(&self, loader_context: &mut LoaderContext) -> Result<()> { #[allow(unused_mut)] let mut inner = || self.loader_impl(loader_context); diff --git a/crates/rspack_macros/src/plugin.rs b/crates/rspack_macros/src/plugin.rs index 7aeeca3bb240..560c9260064a 100644 --- a/crates/rspack_macros/src/plugin.rs +++ b/crates/rspack_macros/src/plugin.rs @@ -182,13 +182,13 @@ pub fn expand_fn(args: HookArgs, input: syn::ItemFn) -> proc_macro::TokenStream let inner_ident = plugin_inner_ident(&name); - let tracing_name = syn::LitStr::new(&format!("{}::{}", &name, &fn_ident), Span::call_site()); + let _tracing_name = syn::LitStr::new(&format!("{}::{}", &name, &fn_ident), Span::call_site()); let tracing_annotation = tracing .map(|bool_lit| bool_lit.value) .unwrap_or(true) .then(|| { quote! { - #[tracing::instrument(name = #tracing_name, skip_all)] + // #[tracing::instrument(name = #tracing_name, skip_all)] } }); diff --git a/crates/rspack_plugin_extract_css/src/css_module.rs b/crates/rspack_plugin_extract_css/src/css_module.rs index 88a4994acbf3..366320f58675 100644 --- a/crates/rspack_plugin_extract_css/src/css_module.rs +++ b/crates/rspack_plugin_extract_css/src/css_module.rs @@ -184,7 +184,7 @@ impl Module for CssModule { }) } - #[tracing::instrument(name = "ExtractCssModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ExtractCssModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, _compilation: &Compilation, diff --git a/crates/rspack_plugin_javascript/src/dependency/esm/esm_export_imported_specifier_dependency.rs b/crates/rspack_plugin_javascript/src/dependency/esm/esm_export_imported_specifier_dependency.rs index 88a5f87a7548..e4dbc51283d7 100644 --- a/crates/rspack_plugin_javascript/src/dependency/esm/esm_export_imported_specifier_dependency.rs +++ b/crates/rspack_plugin_javascript/src/dependency/esm/esm_export_imported_specifier_dependency.rs @@ -1248,7 +1248,7 @@ impl Dependency for ESMExportImportedSpecifierDependency { Some(self.source_order) } - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] fn get_diagnostics(&self, module_graph: &ModuleGraph) -> Option> { let module = module_graph.get_parent_module(&self.id)?; let module = module_graph.module_by_identifier(module)?; diff --git a/crates/rspack_plugin_javascript/src/dependency/esm/esm_import_specifier_dependency.rs b/crates/rspack_plugin_javascript/src/dependency/esm/esm_import_specifier_dependency.rs index b334422fcb80..a3495b38337d 100644 --- a/crates/rspack_plugin_javascript/src/dependency/esm/esm_import_specifier_dependency.rs +++ b/crates/rspack_plugin_javascript/src/dependency/esm/esm_import_specifier_dependency.rs @@ -289,7 +289,7 @@ impl Dependency for ESMImportSpecifierDependency { Some(&self.resource_identifier) } - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] fn get_diagnostics(&self, module_graph: &ModuleGraph) -> Option> { let module = module_graph.get_parent_module(&self.id)?; let module = module_graph.module_by_identifier(module)?; diff --git a/crates/rspack_plugin_javascript/src/parser_and_generator/mod.rs b/crates/rspack_plugin_javascript/src/parser_and_generator/mod.rs index 8c5bd4cdefbf..c125928f9913 100644 --- a/crates/rspack_plugin_javascript/src/parser_and_generator/mod.rs +++ b/crates/rspack_plugin_javascript/src/parser_and_generator/mod.rs @@ -98,6 +98,7 @@ impl ParserAndGenerator for JavaScriptParserAndGenerator { module.original_source().map_or(0, |source| source.size()) as f64 } + #[tracing::instrument("JavaScriptParser:parse", skip_all)] fn parse(&mut self, parse_context: ParseContext) -> Result> { let ParseContext { source, diff --git a/crates/rspack_plugin_javascript/src/plugin/flag_dependency_exports_plugin.rs b/crates/rspack_plugin_javascript/src/plugin/flag_dependency_exports_plugin.rs index 8ecf8e9e2c75..d69814698549 100644 --- a/crates/rspack_plugin_javascript/src/plugin/flag_dependency_exports_plugin.rs +++ b/crates/rspack_plugin_javascript/src/plugin/flag_dependency_exports_plugin.rs @@ -94,7 +94,7 @@ impl<'a> FlagDependencyExportsState<'a> { } } - #[tracing::instrument(skip_all, fields(module = ?self.current_module_id))] + // #[tracing::instrument(skip_all, fields(module = ?self.current_module_id))] pub fn notify_dependencies(&mut self, q: &mut Queue) { if let Some(set) = self.dependencies.get(&self.current_module_id) { for mi in set.iter() { diff --git a/crates/rspack_plugin_lazy_compilation/src/module.rs b/crates/rspack_plugin_lazy_compilation/src/module.rs index b2eabfa229b5..741ba98edff6 100644 --- a/crates/rspack_plugin_lazy_compilation/src/module.rs +++ b/crates/rspack_plugin_lazy_compilation/src/module.rs @@ -183,7 +183,7 @@ impl Module for LazyCompilationProxyModule { }) } - #[tracing::instrument(name = "LazyCompilationProxyModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("LazyCompilationProxyModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_mf/src/container/container_entry_module.rs b/crates/rspack_plugin_mf/src/container/container_entry_module.rs index 5e863bfd885f..40fd71d3b37c 100644 --- a/crates/rspack_plugin_mf/src/container/container_entry_module.rs +++ b/crates/rspack_plugin_mf/src/container/container_entry_module.rs @@ -176,7 +176,7 @@ impl Module for ContainerEntryModule { }) } - #[tracing::instrument(name = "ContainerEntryModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ContainerEntryModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_mf/src/container/fallback_module.rs b/crates/rspack_plugin_mf/src/container/fallback_module.rs index bd9061cc5bef..12b6e0277285 100644 --- a/crates/rspack_plugin_mf/src/container/fallback_module.rs +++ b/crates/rspack_plugin_mf/src/container/fallback_module.rs @@ -146,7 +146,7 @@ impl Module for FallbackModule { }) } - #[tracing::instrument(name = "FallbackModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("FallbackModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_mf/src/container/remote_module.rs b/crates/rspack_plugin_mf/src/container/remote_module.rs index 73e670ea249f..a9588a4d04d4 100644 --- a/crates/rspack_plugin_mf/src/container/remote_module.rs +++ b/crates/rspack_plugin_mf/src/container/remote_module.rs @@ -168,7 +168,7 @@ impl Module for RemoteModule { }) } - #[tracing::instrument(name = "RemoteModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("RemoteModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_mf/src/sharing/consume_shared_module.rs b/crates/rspack_plugin_mf/src/sharing/consume_shared_module.rs index 53c5707382e9..dbbb6618e3c9 100644 --- a/crates/rspack_plugin_mf/src/sharing/consume_shared_module.rs +++ b/crates/rspack_plugin_mf/src/sharing/consume_shared_module.rs @@ -176,7 +176,7 @@ impl Module for ConsumeSharedModule { }) } - #[tracing::instrument(name = "ConsumeSharedModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ConsumeSharedModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_mf/src/sharing/provide_shared_module.rs b/crates/rspack_plugin_mf/src/sharing/provide_shared_module.rs index ed0d1adf0991..ec4a163cef59 100644 --- a/crates/rspack_plugin_mf/src/sharing/provide_shared_module.rs +++ b/crates/rspack_plugin_mf/src/sharing/provide_shared_module.rs @@ -171,7 +171,7 @@ impl Module for ProvideSharedModule { }) } - #[tracing::instrument(name = "ProvideSharedModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] + // #[tracing::instrument("ProvideSharedModule::code_generation", skip_all, fields(identifier = ?self.identifier()))] fn code_generation( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_split_chunks/src/plugin/chunk.rs b/crates/rspack_plugin_split_chunks/src/plugin/chunk.rs index 42c5b6ebdee2..a217cc399dc9 100644 --- a/crates/rspack_plugin_split_chunks/src/plugin/chunk.rs +++ b/crates/rspack_plugin_split_chunks/src/plugin/chunk.rs @@ -158,7 +158,7 @@ impl SplitChunksPlugin { } /// This de-duplicated each module fro other chunks, make sure there's only one copy of each module. - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn move_modules_to_new_chunk_and_remove_from_old_chunks( &self, item: &ModuleGroup, @@ -196,7 +196,7 @@ impl SplitChunksPlugin { /// create a connection between the `new_chunk` and `original_chunks`. /// Thus, if `original_chunks` want to know which chunk contains moved modules, /// it could easily find out. - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn split_from_original_chunks( &self, _item: &ModuleGroup, diff --git a/crates/rspack_plugin_split_chunks/src/plugin/max_request.rs b/crates/rspack_plugin_split_chunks/src/plugin/max_request.rs index e180f7b1ea84..ba450af62cce 100644 --- a/crates/rspack_plugin_split_chunks/src/plugin/max_request.rs +++ b/crates/rspack_plugin_split_chunks/src/plugin/max_request.rs @@ -8,7 +8,7 @@ use crate::{CacheGroup, SplitChunksPlugin}; impl SplitChunksPlugin { /// Affected by `splitChunks.maxInitialRequests`/`splitChunks.cacheGroups.{cacheGroup}.maxInitialRequests` /// Affected by `splitChunks.maxAsyncRequests`/`splitChunks.cacheGroups.{cacheGroup}.maxAsyncRequests` - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn ensure_max_request_fit( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_split_chunks/src/plugin/max_size.rs b/crates/rspack_plugin_split_chunks/src/plugin/max_size.rs index dfd1bea6d8d3..2e2ac89b19e1 100644 --- a/crates/rspack_plugin_split_chunks/src/plugin/max_size.rs +++ b/crates/rspack_plugin_split_chunks/src/plugin/max_size.rs @@ -276,7 +276,7 @@ fn similarity(a: &str, b: &str) -> usize { impl SplitChunksPlugin { /// Affected by `splitChunks.minSize`/`splitChunks.cacheGroups.{cacheGroup}.minSize` - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(super) fn ensure_max_size_fit( &self, compilation: &mut Compilation, diff --git a/crates/rspack_plugin_split_chunks/src/plugin/min_size.rs b/crates/rspack_plugin_split_chunks/src/plugin/min_size.rs index b86666f65a60..08db6316f3a1 100644 --- a/crates/rspack_plugin_split_chunks/src/plugin/min_size.rs +++ b/crates/rspack_plugin_split_chunks/src/plugin/min_size.rs @@ -70,7 +70,7 @@ impl SplitChunksPlugin { } /// Affected by `splitChunks.minSize`/`splitChunks.cacheGroups.{cacheGroup}.minSize` - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn ensure_min_size_fit( &self, compilation: &Compilation, diff --git a/crates/rspack_plugin_split_chunks/src/plugin/mod.rs b/crates/rspack_plugin_split_chunks/src/plugin/mod.rs index d58761da86f9..0e8807c72a6d 100644 --- a/crates/rspack_plugin_split_chunks/src/plugin/mod.rs +++ b/crates/rspack_plugin_split_chunks/src/plugin/mod.rs @@ -63,10 +63,10 @@ impl SplitChunksPlugin { module_group_key, module_group_map.len(), ); - let process_span = tracing::trace_span!("Process ModuleGroup({})", module_group_key); + // let process_span = tracing::trace_span!("Process ModuleGroup"); - process_span.in_scope(|| { - let cache_group = module_group.get_cache_group(&self.cache_groups); + // process_span.in_scope(|| { + let cache_group = module_group.get_cache_group(&self.cache_groups); let mut is_reuse_existing_chunk = false; let mut is_reuse_existing_chunk_with_all_modules = false; @@ -111,7 +111,8 @@ impl SplitChunksPlugin { if used_chunks_len < cache_group.min_chunks as usize { // `min_size` is not satisfied, ignore this invalid `ModuleGroup` tracing::trace!("ModuleGroup({module_group_key}) is skipped. Reason: used_chunks_len({used_chunks_len:?}) < cache_group.min_chunks({:?})", cache_group.min_chunks); - return; + continue; + // return; } } @@ -142,7 +143,7 @@ impl SplitChunksPlugin { &used_chunks, compilation, ); - }) + // }) } logger.time_end(start); diff --git a/crates/rspack_plugin_split_chunks/src/plugin/module_group.rs b/crates/rspack_plugin_split_chunks/src/plugin/module_group.rs index f88a7cfb7306..14410f233a66 100644 --- a/crates/rspack_plugin_split_chunks/src/plugin/module_group.rs +++ b/crates/rspack_plugin_split_chunks/src/plugin/module_group.rs @@ -252,7 +252,7 @@ impl Combinator { } impl SplitChunksPlugin { - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn find_best_module_group( &self, module_group_map: &mut ModuleGroupMap, @@ -276,7 +276,7 @@ impl SplitChunksPlugin { (best_entry_key, best_module_group) } - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn prepare_module_group_map( &self, compilation: &Compilation, @@ -499,7 +499,7 @@ impl SplitChunksPlugin { Ok(module_group_map.into_iter().collect()) } - #[tracing::instrument(skip_all)] + // #[tracing::instrument(skip_all)] pub(crate) fn remove_all_modules_from_other_module_groups( &self, current_module_group: &ModuleGroup, diff --git a/crates/rspack_tracing/Cargo.toml b/crates/rspack_tracing/Cargo.toml index ab3d079336dd..07265b473aa6 100644 --- a/crates/rspack_tracing/Cargo.toml +++ b/crates/rspack_tracing/Cargo.toml @@ -9,6 +9,10 @@ version = "0.2.0" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [dependencies] -tracing = { workspace = true } -tracing-chrome = "0.7.2" -tracing-subscriber = { workspace = true, features = ["env-filter"] } +opentelemetry = "0.26.0" +opentelemetry-otlp = "0.26.0" +opentelemetry_sdk = { version = "0.26.0", features = ["rt-tokio"] } +tracing = { workspace = true } +tracing-chrome = "0.7.2" +tracing-opentelemetry = "0.27.0" +tracing-subscriber = { workspace = true, features = ["env-filter"] } diff --git a/crates/rspack_tracing/src/chrome.rs b/crates/rspack_tracing/src/chrome.rs new file mode 100644 index 000000000000..d39b01c518ac --- /dev/null +++ b/crates/rspack_tracing/src/chrome.rs @@ -0,0 +1,44 @@ +use tracing_chrome::{ChromeLayerBuilder, FlushGuard}; +use tracing_subscriber::layer::{Filter, Layer}; + +use crate::{ + tracer::{Layered, Tracer}, + TraceWriter, +}; + +#[derive(Default)] +pub struct ChromeTracer { + guard: Option, +} + +impl Tracer for ChromeTracer { + fn setup(&mut self, output: &str) -> Option { + let trace_writer = TraceWriter::from(output); + let (chrome_layer, guard) = ChromeLayerBuilder::new() + .include_args(true) + .writer(trace_writer.writer()) + .build(); + self.guard = Some(guard); + + Some(vec![chrome_layer.with_filter(FilterEvent {}).boxed()].boxed()) + } + + fn teardown(&mut self) { + if let Some(guard) = self.guard.take() { + guard.flush(); + } + } +} + +// skip event because it's not useful for performance analysis +struct FilterEvent; + +impl Filter for FilterEvent { + fn enabled( + &self, + meta: &tracing::Metadata<'_>, + _cx: &tracing_subscriber::layer::Context<'_, S>, + ) -> bool { + !meta.is_event() + } +} diff --git a/crates/rspack_tracing/src/lib.rs b/crates/rspack_tracing/src/lib.rs index 6f0017529d1a..b82d572a1798 100644 --- a/crates/rspack_tracing/src/lib.rs +++ b/crates/rspack_tracing/src/lib.rs @@ -1,113 +1,23 @@ -use std::fs; -use std::io; -use std::path::Path; -use std::str::FromStr; -use std::sync::atomic::AtomicBool; -use std::sync::atomic::Ordering; +mod chrome; +mod opentelemetry; +mod stdout; +mod tracer; -use tracing::Level; -use tracing_chrome::FlushGuard; -use tracing_subscriber::fmt::writer::BoxMakeWriter; -use tracing_subscriber::{fmt::format::FmtSpan, layer::Filter}; -use tracing_subscriber::{EnvFilter, Layer}; - -pub mod chrome { - pub use tracing_chrome::FlushGuard; -} - -static IS_TRACING_ENABLED: AtomicBool = AtomicBool::new(false); - -// skip event because it's not useful for performance analysis -struct FilterEvent; - -impl Filter for FilterEvent { - fn enabled( - &self, - meta: &tracing::Metadata<'_>, - _cx: &tracing_subscriber::layer::Context<'_, S>, - ) -> bool { - !meta.is_event() - } -} - -pub fn enable_tracing_by_env(filter: &str, output: &str) { - if !IS_TRACING_ENABLED.swap(true, Ordering::Relaxed) { - use tracing_subscriber::{fmt, prelude::*}; - let layers = generate_common_layers(filter); - let trace_writer = TraceWriter::from(output); +use std::{fs, io, path::Path}; - tracing_subscriber::registry() - // .with(EnvFilter::from_env("TRACE").and_then(rspack_only_layer)) - .with(layers) - .with( - fmt::layer() - .pretty() - .with_file(true) - // To keep track of the closing point of spans - .with_span_events(FmtSpan::CLOSE) - .with_writer(trace_writer.make_writer()), - ) - .init(); - tracing::trace!("enable_tracing_by_env"); - } -} - -fn generate_common_layers( - filter: &str, -) -> Vec + Send + Sync>> { - let default_level = Level::from_str(filter).ok(); - - let mut layers = vec![]; - if let Some(default_level) = default_level { - layers.push( - tracing_subscriber::filter::Targets::new() - .with_targets(vec![ - ("rspack_core", default_level), - ("rspack", default_level), - ("rspack_node", default_level), - ("rspack_plugin_javascript", default_level), - ("rspack_plugin_split_chunks", default_level), - ("rspack_binding_values", default_level), - ]) - .boxed(), - ); - } else { - // SAFETY: we know that trace_var is `Ok(StrinG)` now, - // for the second unwrap, if we can't parse the directive, then the tracing result would be - // unexpected, then panic is reasonable - let env_layer = EnvFilter::builder() - .with_regex(true) - .parse(filter) - .expect("Parse tracing directive syntax failed,for details about the directive syntax you could refer https://docs.rs/tracing-subscriber/latest/tracing_subscriber/filter/struct.EnvFilter.html#directives"); - - layers.push(env_layer.boxed()); - } - layers -} +pub use chrome::ChromeTracer; +pub use opentelemetry::OtelTracer; +pub use stdout::StdoutTracer; +pub use tracer::Tracer; +use tracing_subscriber::fmt::writer::BoxMakeWriter; -pub fn enable_tracing_by_env_with_chrome_layer(filter: &str, output: &str) -> Option { - if !IS_TRACING_ENABLED.swap(true, Ordering::Relaxed) { - use tracing_chrome::ChromeLayerBuilder; - use tracing_subscriber::prelude::*; - let trace_writer = TraceWriter::from(output); - let (chrome_layer, guard) = ChromeLayerBuilder::new() - .include_args(true) - .writer(trace_writer.writer()) - .build(); - let layers = generate_common_layers(filter); - // If we don't do this. chrome_layer will collect nothing. - // std::mem::forget(guard); - tracing_subscriber::registry() - .with(layers) - .with(chrome_layer.with_filter(FilterEvent {})) - .init(); - Some(guard) - } else { - None - } +pub mod otel { + pub use opentelemetry; + pub use opentelemetry_sdk as sdk; + pub use tracing_opentelemetry as tracing; } -enum TraceWriter<'a> { +pub(crate) enum TraceWriter<'a> { Stdout, Stderr, File { path: &'a Path }, diff --git a/crates/rspack_tracing/src/opentelemetry.rs b/crates/rspack_tracing/src/opentelemetry.rs new file mode 100644 index 000000000000..f9839686679c --- /dev/null +++ b/crates/rspack_tracing/src/opentelemetry.rs @@ -0,0 +1,47 @@ +use opentelemetry::{global, trace::TracerProvider as _, KeyValue}; +use opentelemetry_sdk::{propagation::TraceContextPropagator, runtime, Resource}; +use tracing_opentelemetry::OpenTelemetryLayer; +use tracing_subscriber::Layer; + +use super::tracer::Tracer; +use crate::tracer::Layered; + +pub struct OtelTracer { + provider: opentelemetry_sdk::trace::TracerProvider, +} + +impl Default for OtelTracer { + fn default() -> Self { + Self::new() + } +} + +impl OtelTracer { + fn new() -> Self { + let provider = + opentelemetry_otlp::new_pipeline() + .tracing() + .with_exporter(opentelemetry_otlp::new_exporter().tonic()) + .with_trace_config(opentelemetry_sdk::trace::Config::default().with_resource( + Resource::new(vec![KeyValue::new("service.name", "rspack-app")]), + )) + .install_batch(runtime::Tokio) + .expect("Should be able to initialize open telemetry"); + + Self { provider } + } +} + +impl Tracer for OtelTracer { + fn setup(&mut self, _output: &str) -> Option { + global::set_text_map_propagator(TraceContextPropagator::new()); + global::set_tracer_provider(self.provider.clone()); + let trace = self.provider.tracer("rspack-app"); + Some(OpenTelemetryLayer::new(trace).boxed()) + } + + fn teardown(&mut self) { + let _ = self.provider.shutdown(); + opentelemetry::global::shutdown_tracer_provider(); + } +} diff --git a/crates/rspack_tracing/src/stdout.rs b/crates/rspack_tracing/src/stdout.rs new file mode 100644 index 000000000000..aed93b035989 --- /dev/null +++ b/crates/rspack_tracing/src/stdout.rs @@ -0,0 +1,28 @@ +use tracing_subscriber::fmt::format::FmtSpan; + +use crate::{ + tracer::{Layered, Tracer}, + TraceWriter, +}; + +pub struct StdoutTracer; + +impl Tracer for StdoutTracer { + fn setup(&mut self, output: &str) -> Option { + use tracing_subscriber::{fmt, prelude::*}; + let trace_writer = TraceWriter::from(output); + Some( + fmt::layer() + .pretty() + .with_file(true) + // To keep track of the closing point of spans + .with_span_events(FmtSpan::CLOSE) + .with_writer(trace_writer.make_writer()) + .boxed(), + ) + } + + fn teardown(&mut self) { + // noop + } +} diff --git a/crates/rspack_tracing/src/tracer.rs b/crates/rspack_tracing/src/tracer.rs new file mode 100644 index 000000000000..aac899f34eb4 --- /dev/null +++ b/crates/rspack_tracing/src/tracer.rs @@ -0,0 +1,8 @@ +use tracing_subscriber::{Layer, Registry}; + +pub type Layered = Box + Send + Sync>; + +pub trait Tracer { + fn setup(&mut self, output: &str) -> Option; + fn teardown(&mut self); +} diff --git a/packages/rspack-cli/package.json b/packages/rspack-cli/package.json index 8976027beaf0..7caf77350ba3 100644 --- a/packages/rspack-cli/package.json +++ b/packages/rspack-cli/package.json @@ -35,6 +35,7 @@ "dependencies": { "@discoveryjs/json-ext": "^0.5.7", "@rspack/dev-server": "1.0.10", + "@rspack/tracing": "workspace:*", "colorette": "2.0.19", "exit-hook": "^4.0.0", "interpret": "^3.1.1", diff --git a/packages/rspack-cli/src/utils/profile.ts b/packages/rspack-cli/src/utils/profile.ts index 046ad8d0626d..f0531b262bbf 100644 --- a/packages/rspack-cli/src/utils/profile.ts +++ b/packages/rspack-cli/src/utils/profile.ts @@ -122,6 +122,11 @@ function resolveJSCPUProfileOptions(value: string): JSCPUProfileOptions { return { output: value || defaultJSCPUProfileOutput }; } +function isSupportedLayer(layer: string): layer is RustTraceOptionsLayer { + const SUPPORTED_LAYERS = ["chrome", "logger", "otel"]; + return SUPPORTED_LAYERS.includes(layer); +} + // TRACE=value function resolveRustTraceOptions(value: string): RustTraceOptions { // filter=trace&output=stdout&layer=logger @@ -133,7 +138,8 @@ function resolveRustTraceOptions(value: string): RustTraceOptions { layer === "chrome" ? parsed.get("output") || defaultRustTraceChromeOutput : parsed.get("output") || defaultRustTraceLoggerOutput; - if (layer !== "chrome" && layer !== "logger") { + + if (!isSupportedLayer(layer)) { throw new Error( `${layer} is not a valid layer, should be chrome or logger` ); @@ -209,19 +215,21 @@ class RspackProfileLoggingPlugin { } export async function applyProfile(profileValue: string, item: RspackOptions) { - const { default: exitHook } = await import("exit-hook"); + const { asyncExitHook } = await import("exit-hook"); const entries = Object.entries(resolveProfile(profileValue)); if (entries.length <= 0) return; await fs.promises.mkdir(defaultOutputDirname); for (const [kind, value] of entries) { await ensureFileDir(value.output); if (kind === "TRACE" && "filter" in value) { - rspack.experiments.globalTrace.register( + await rspack.experiments.globalTrace.register( value.filter, value.layer, value.output ); - exitHook(rspack.experiments.globalTrace.cleanup); + asyncExitHook(rspack.experiments.globalTrace.cleanup, { + wait: 500 + }); } else if (kind === "JSCPU") { (item.plugins ??= []).push( new RspackProfileJSCPUProfilePlugin(value.output) diff --git a/packages/rspack-cli/tests/build/profile/profile.test.ts b/packages/rspack-cli/tests/build/profile/profile.test.ts index 73ce77f8a8d7..601a993bb28d 100644 --- a/packages/rspack-cli/tests/build/profile/profile.test.ts +++ b/packages/rspack-cli/tests/build/profile/profile.test.ts @@ -124,9 +124,9 @@ describe("profile", () => { __dirname, [], {}, - { RSPACK_PROFILE: `TRACE=layer=logger&filter=rspack_node::plugins` } + { RSPACK_PROFILE: `TRACE=layer=logger&filter=rspack_core::compiler` } ); expect(exitCode).toBe(0); - expect(stdout.includes("rspack_node::plugins")).toBe(true); + expect(stdout.includes("rspack_core::compiler")).toBe(true); }); }); diff --git a/packages/rspack-test-tools/etc/test-tools.api.md b/packages/rspack-test-tools/etc/test-tools.api.md index 3873d9f4cdd4..2810d89b6428 100644 --- a/packages/rspack-test-tools/etc/test-tools.api.md +++ b/packages/rspack-test-tools/etc/test-tools.api.md @@ -1,4 +1,4 @@ -## API report file for "@rspack/test-tools" +## API Report File for "@rspack/test-tools" > Do not edit this file. It is a report generated by [API Extractor](https://api-extractor.com/). diff --git a/packages/rspack-tracing/index.d.ts b/packages/rspack-tracing/index.d.ts new file mode 100644 index 000000000000..dcdb37aa213c --- /dev/null +++ b/packages/rspack-tracing/index.d.ts @@ -0,0 +1,3 @@ +export function initOpenTelemetry(): Promise; +export function shutdownOpenTelemetry(): Promise; +export { trace, propagation, context } from "@opentelemetry/api"; diff --git a/packages/rspack-tracing/index.js b/packages/rspack-tracing/index.js new file mode 100644 index 000000000000..d1a7674114e5 --- /dev/null +++ b/packages/rspack-tracing/index.js @@ -0,0 +1,34 @@ +let sdk; + +export async function initOpenTelemetry() { + if (sdk) return; + const otel = await import("@opentelemetry/sdk-node"); + const { Resource } = await import("@opentelemetry/resources"); + const { OTLPTraceExporter } = await import( + "@opentelemetry/exporter-trace-otlp-proto" + ); + const { AsyncHooksContextManager } = await import( + "@opentelemetry/context-async-hooks" + ); + const contextManager = new AsyncHooksContextManager(); + contextManager.enable(); + otel.api.context.setGlobalContextManager(contextManager); + + sdk = new otel.NodeSDK({ + resource: new Resource({ + "service.name": "rspack-app" + }), + traceExporter: new OTLPTraceExporter() + }); + sdk.start(); +} + +export async function shutdownOpenTelemetry() { + if (!sdk) return; + const otel = await import("@opentelemetry/sdk-node"); + await sdk.shutdown(); + otel.api.context.disable(); + sdk = null; +} + +export { trace, propagation, context } from "@opentelemetry/api"; diff --git a/packages/rspack-tracing/package.json b/packages/rspack-tracing/package.json new file mode 100644 index 000000000000..fd9774b70aac --- /dev/null +++ b/packages/rspack-tracing/package.json @@ -0,0 +1,27 @@ +{ + "name": "@rspack/tracing", + "version": "1.0.12", + "private": true, + "type": "module", + "description": "Internal tracing package for rspack", + "homepage": "https://rspack.dev", + "bugs": "https://github.com/web-infra-dev/rspack/issues", + "repository": { + "type": "git", + "url": "https://github.com/web-infra-dev/rspack", + "directory": "packages/rspack-tracing" + }, + "license": "MIT", + "main": "./index.js", + "types": "./index.d.ts", + "scripts": { + "build": "tsc -b ./tsconfig.build.json" + }, + "dependencies": { + "@opentelemetry/api": "^1.9.0", + "@opentelemetry/context-async-hooks": "^1.26.0", + "@opentelemetry/exporter-trace-otlp-proto": "^0.54.2", + "@opentelemetry/resources": "^1.26.0", + "@opentelemetry/sdk-node": "^0.54.2" + } +} \ No newline at end of file diff --git a/packages/rspack-tracing/tsconfig.build.json b/packages/rspack-tracing/tsconfig.build.json new file mode 100644 index 000000000000..cfa29a22fa1d --- /dev/null +++ b/packages/rspack-tracing/tsconfig.build.json @@ -0,0 +1,10 @@ +{ + "compilerOptions": { + "allowJs": true, + "checkJs": true, + "outDir": ".", + "emitDeclarationOnly": true, + "declaration": true + }, + "exclude": ["index.d.ts"] +} diff --git a/packages/rspack/etc/core.api.md b/packages/rspack/etc/core.api.md index f74615e55db0..f53e5d804894 100644 --- a/packages/rspack/etc/core.api.md +++ b/packages/rspack/etc/core.api.md @@ -1,4 +1,4 @@ -## API report file for "@rspack/core" +## API Report File for "@rspack/core" > Do not edit this file. It is a report generated by [API Extractor](https://api-extractor.com/). @@ -15,7 +15,6 @@ import { BuiltinPlugin } from '@rspack/binding'; import { BuiltinPluginName } from '@rspack/binding'; import { CacheFacade as CacheFacade_2 } from './lib/CacheFacade'; import type { Callback } from '@rspack/lite-tapable'; -import { cleanupGlobalTrace } from '@rspack/binding'; import { Compiler as Compiler_2 } from '..'; import { default as default_2 } from './util/hash'; import { RawEvalDevToolModulePluginOptions as EvalDevToolModulePluginOptions } from '@rspack/binding'; @@ -66,7 +65,6 @@ import { RawOptions } from '@rspack/binding'; import { RawProgressPluginOptions } from '@rspack/binding'; import { RawProvideOptions } from '@rspack/binding'; import { RawRuntimeChunkOptions } from '@rspack/binding'; -import { registerGlobalTrace } from '@rspack/binding'; import { RspackOptionsNormalized as RspackOptionsNormalized_2 } from '.'; import { RawSourceMapDevToolPluginOptions as SourceMapDevToolPluginOptions } from '@rspack/binding'; import sources = require('../compiled/webpack-sources'); @@ -1967,8 +1965,8 @@ export const experiments: Experiments_2; interface Experiments_2 { // (undocumented) globalTrace: { - register: typeof registerGlobalTrace; - cleanup: typeof cleanupGlobalTrace; + register: (filter: string, layer: "chrome" | "logger" | "otel", output: string) => Promise; + cleanup: () => Promise; }; // (undocumented) RemoveDuplicateModulesPlugin: typeof RemoveDuplicateModulesPlugin; diff --git a/packages/rspack/package.json b/packages/rspack/package.json index 15d1c52a3711..681d794ff1ae 100644 --- a/packages/rspack/package.json +++ b/packages/rspack/package.json @@ -73,6 +73,7 @@ "dependencies": { "@module-federation/runtime-tools": "0.8.4", "@rspack/binding": "workspace:*", + "@rspack/tracing": "workspace:*", "@rspack/lite-tapable": "1.0.1", "caniuse-lite": "^1.0.30001616" }, diff --git a/packages/rspack/src/exports.ts b/packages/rspack/src/exports.ts index 4202b6ee53e3..4bb28e71af0e 100644 --- a/packages/rspack/src/exports.ts +++ b/packages/rspack/src/exports.ts @@ -293,16 +293,30 @@ export type { import { cleanupGlobalTrace, registerGlobalTrace } from "@rspack/binding"; interface Experiments { globalTrace: { - register: typeof registerGlobalTrace; - cleanup: typeof cleanupGlobalTrace; + register: ( + filter: string, + layer: "chrome" | "logger" | "otel", + output: string + ) => Promise; + cleanup: () => Promise; }; RemoveDuplicateModulesPlugin: typeof RemoveDuplicateModulesPlugin; } export const experiments: Experiments = { globalTrace: { - register: registerGlobalTrace, - cleanup: cleanupGlobalTrace + async register(filter, layer, output) { + registerGlobalTrace(filter, layer, output); + if (layer === "otel") { + const { initOpenTelemetry } = await import("@rspack/tracing"); + await initOpenTelemetry(); + } + }, + async cleanup() { + cleanupGlobalTrace(); + const { shutdownOpenTelemetry } = await import("@rspack/tracing"); + await shutdownOpenTelemetry(); + } }, RemoveDuplicateModulesPlugin }; diff --git a/packages/rspack/src/loader-runner/index.ts b/packages/rspack/src/loader-runner/index.ts index a90e51167210..151188086e09 100644 --- a/packages/rspack/src/loader-runner/index.ts +++ b/packages/rspack/src/loader-runner/index.ts @@ -344,6 +344,17 @@ export async function runLoaders( compiler: Compiler, context: JsLoaderContext ): Promise { + const { + trace, + propagation, + context: tracingContext + } = await import("@rspack/tracing"); + const tracer = trace.getTracer("rspack-loader-runner"); + const activeContext = propagation.extract( + tracingContext.active(), + context.__internal__tracingCarrier + ); + const loaderState = context.loaderState; // @@ -811,12 +822,22 @@ export async function runLoaders( currentLoaderObject.pitchExecuted = true; if (!fn) continue; + const span = tracer.startSpan( + "LoaderRunner:pitch", + { + attributes: { + "loader.identifier": getCurrentLoader(loaderContext)?.request + } + }, + activeContext + ); const args = (await runSyncOrAsync(fn, loaderContext, [ loaderContext.remainingRequest, loaderContext.previousRequest, currentLoaderObject.data ])) || []; + span.end(); const hasArg = args.some(value => value !== undefined); @@ -852,8 +873,19 @@ export async function runLoaders( if (!fn) continue; const args = [content, sourceMap, additionalData]; convertArgs(args, !!currentLoaderObject.raw); + + const span = tracer.startSpan( + "LoaderRunner:normal", + { + attributes: { + "loader.identifier": getCurrentLoader(loaderContext)?.request + } + }, + activeContext + ); [content, sourceMap, additionalData] = (await runSyncOrAsync(fn, loaderContext, args)) || []; + span.end(); } context.content = isNil(content) ? null : toBuffer(content); diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 57d4c8156db8..482847de9d86 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -300,6 +300,9 @@ importers: '@rspack/lite-tapable': specifier: 1.0.1 version: 1.0.1 + '@rspack/tracing': + specifier: workspace:* + version: link:../rspack-tracing '@swc/helpers': specifier: '>=0.5.1' version: 0.5.13 @@ -376,6 +379,9 @@ importers: '@rspack/dev-server': specifier: 1.0.10 version: 1.0.10(@rspack/core@packages+rspack)(@types/express@4.17.21)(webpack-cli@5.1.4(webpack@5.95.0))(webpack@5.95.0(@swc/core@1.10.1(@swc/helpers@0.5.15))(webpack-cli@5.1.4(webpack@5.95.0))) + '@rspack/tracing': + specifier: workspace:* + version: link:../rspack-tracing colorette: specifier: 2.0.19 version: 2.0.19 @@ -655,6 +661,24 @@ importers: specifier: ^18.2.0 version: 18.3.1 + packages/rspack-tracing: + dependencies: + '@opentelemetry/api': + specifier: ^1.9.0 + version: 1.9.0 + '@opentelemetry/context-async-hooks': + specifier: ^1.26.0 + version: 1.26.0(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-trace-otlp-proto': + specifier: ^0.54.2 + version: 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': + specifier: ^1.26.0 + version: 1.26.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-node': + specifier: ^0.54.2 + version: 0.54.2(@opentelemetry/api@1.9.0) + scripts: devDependencies: '@actions/core': @@ -2011,6 +2035,15 @@ packages: resolution: {integrity: sha512-vBZP4NlzfOlerQTnba4aqZoMhE/a9HY7HRqoOPaETQcSQuWEIyZMHGfVu6w9wGtGK5fED5qRs2DteVCjOH60sA==} engines: {node: '>=14'} + '@grpc/grpc-js@1.12.2': + resolution: {integrity: sha512-bgxdZmgTrJZX50OjyVwz3+mNEnCTNkh3cIqGPWVNeW9jX6bn1ZkU80uPd+67/ZpIJIjRQ9qaHCjhavyoWYxumg==} + engines: {node: '>=12.10.0'} + + '@grpc/proto-loader@0.7.13': + resolution: {integrity: sha512-AiXO/bfe9bmxBjxxtYxFAXGZvMaN5s8kO+jBHAJCON8rJoB5YS/D6X7ZNc6XQkuHNmyl4CYaMI1fJ/Gn27RGGw==} + engines: {node: '>=6'} + hasBin: true + '@gwhitney/detect-indent@7.0.1': resolution: {integrity: sha512-7bQW+gkKa2kKZPeJf6+c6gFK9ARxQfn+FKy9ScTBppyKRWH2KzsmweXUoklqeEiHiNVWaeP5csIdsNq6w7QhzA==} engines: {node: '>=12.20'} @@ -2207,6 +2240,9 @@ packages: '@jridgewell/trace-mapping@0.3.9': resolution: {integrity: sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==} + '@js-sdsl/ordered-map@4.4.2': + resolution: {integrity: sha512-iUKgm52T8HOE/makSxjqoWhe95ZJA1/G1sYsGev2JDKUSS14KAgg1LHb+Ba+IPow0xflbnSkOsZcO08C7w1gYw==} + '@jsonjoy.com/base64@1.1.2': resolution: {integrity: sha512-q6XAnWQDIMA3+FTiOYajoYqySkO+JSat0ytXGSuRdq9uXE7o92gzuQwQM14xaCRlBLGq3v5miDGC4vkVTn54xA==} engines: {node: '>=10.0'} @@ -2689,6 +2725,162 @@ packages: '@octokit/types@13.6.1': resolution: {integrity: sha512-PHZE9Z+kWXb23Ndik8MKPirBPziOc0D2/3KH1P+6jK5nGWe96kadZuE4jev2/Jq7FvIfTlT2Ltg8Fv2x1v0a5g==} + '@opentelemetry/api-logs@0.54.2': + resolution: {integrity: sha512-4MTVwwmLgUh5QrJnZpYo6YRO5IBLAggf2h8gWDblwRagDStY13aEvt7gGk3jewrMaPlHiF83fENhIx0HO97/cQ==} + engines: {node: '>=14'} + + '@opentelemetry/api@1.9.0': + resolution: {integrity: sha512-3giAOQvZiH5F9bMlMiv8+GSPMeqg0dbaeo58/0SlA9sxSqZhnUtxzX9/2FzyhS9sWQf5S0GJE0AKBrFqjpeYcg==} + engines: {node: '>=8.0.0'} + + '@opentelemetry/context-async-hooks@1.26.0': + resolution: {integrity: sha512-HedpXXYzzbaoutw6DFLWLDket2FwLkLpil4hGCZ1xYEIMTcivdfwEOISgdbLEWyG3HW52gTq2V9mOVJrONgiwg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/context-async-hooks@1.27.0': + resolution: {integrity: sha512-CdZ3qmHCwNhFAzjTgHqrDQ44Qxcpz43cVxZRhOs+Ns/79ug+Mr84Bkb626bkJLkA3+BLimA5YAEVRlJC6pFb7g==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/core@1.26.0': + resolution: {integrity: sha512-1iKxXXE8415Cdv0yjG3G6hQnB5eVEsJce3QaawX8SjDn0mAS0ZM8fAbZZJD4ajvhC15cePvosSCut404KrIIvQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/core@1.27.0': + resolution: {integrity: sha512-yQPKnK5e+76XuiqUH/gKyS8wv/7qITd5ln56QkBTf3uggr0VkXOXfcaAuG330UfdYu83wsyoBwqwxigpIG+Jkg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/exporter-logs-otlp-grpc@0.54.2': + resolution: {integrity: sha512-MQNmV5r96+5n3axLFgNYtVy62x8Ru7VERZH3zgC50KDcIKWCiQT3vHOtzakhzd1Wq0HqOgu6bzKdwzneSoDrEQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/exporter-logs-otlp-http@0.54.2': + resolution: {integrity: sha512-wYeCSbX2XWX2wFslnfQ/YFUolO0fj2nUiGI7oEQWpLKSg40Lc4xOOW14X/EXOkCCijhP7bigo6nvyEQlxEVLjA==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/exporter-logs-otlp-proto@0.54.2': + resolution: {integrity: sha512-agrzFbSNmIy6dhkyg41ERlEDUDqkaUJj2n/tVRFp9Tl+6wyNVPsqmwU5RWJOXpyK+lYH/znv6A47VpTeJF0lrw==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/exporter-trace-otlp-grpc@0.54.2': + resolution: {integrity: sha512-tmxiCYhQdPrzwlM6O7VQeNP9PBjKhaiOo54wFxQFZQcoVaDiOOES4+6PwHU1eW+43mDsgdQHN5AHSRHVLe9jDA==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/exporter-trace-otlp-http@0.54.2': + resolution: {integrity: sha512-BgWKKyD/h2zpISdmYHN/sapwTjvt1P4p5yx4xeBV8XAEqh4OQUhOtSGFG80+nPQ1F8of3mKOT1DDoDbJp1u25w==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/exporter-trace-otlp-proto@0.54.2': + resolution: {integrity: sha512-XSmm1N2wAhoWDXP1q/N6kpLebWaxl6VIADv4WA5QWKHLRpF3gLz5NAWNJBR8ygsvv8jQcrwnXgwfnJ18H3v1fg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/exporter-zipkin@1.27.0': + resolution: {integrity: sha512-eGMY3s4QprspFZojqsuQyQpWNFpo+oNVE/aosTbtvAlrJBAlvXcwwsOROOHOd8Y9lkU4i0FpQW482rcXkgwCSw==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.0.0 + + '@opentelemetry/instrumentation@0.54.2': + resolution: {integrity: sha512-go6zpOVoZVztT9r1aPd79Fr3OWiD4N24bCPJsIKkBses8oyFo12F/Ew3UBTdIu6hsW4HC4MVEJygG6TEyJI/lg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/otlp-exporter-base@0.54.2': + resolution: {integrity: sha512-NrNyxu6R/bGAwanhz1HI0aJWKR6xUED4TjCH4iWMlAfyRukGbI9Kt/Akd2sYLwRKNhfS+sKetKGCUQPMDyYYMA==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/otlp-grpc-exporter-base@0.54.2': + resolution: {integrity: sha512-HZtACQuLhgDcgNa9arGnVVGV28sSGQ+iwRgICWikFKiVxUsoWffqBvTxPa6G3DUTg5R+up97j/zxubEyxSAOHg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/otlp-transformer@0.54.2': + resolution: {integrity: sha512-2tIjahJlMRRUz0A2SeE+qBkeBXBFkSjR0wqJ08kuOqaL8HNGan5iZf+A8cfrfmZzPUuMKCyY9I+okzFuFs6gKQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': ^1.3.0 + + '@opentelemetry/propagator-b3@1.27.0': + resolution: {integrity: sha512-pTsko3gnMioe3FeWcwTQR3omo5C35tYsKKwjgTCTVCgd3EOWL9BZrMfgLBmszrwXABDfUrlAEFN/0W0FfQGynQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/propagator-jaeger@1.27.0': + resolution: {integrity: sha512-EI1bbK0wn0yIuKlc2Qv2LKBRw6LiUWevrjCF80fn/rlaB+7StAi8Y5s8DBqAYNpY7v1q86+NjU18v7hj2ejU3A==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/resources@1.26.0': + resolution: {integrity: sha512-CPNYchBE7MBecCSVy0HKpUISEeJOniWqcHaAHpmasZ3j9o6V3AyBzhRc90jdmemq0HOxDr6ylhUbDhBqqPpeNw==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/resources@1.27.0': + resolution: {integrity: sha512-jOwt2VJ/lUD5BLc+PMNymDrUCpm5PKi1E9oSVYAvz01U/VdndGmrtV3DU1pG4AwlYhJRHbHfOUIlpBeXCPw6QQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/sdk-logs@0.54.2': + resolution: {integrity: sha512-yIbYqDLS/AtBbPjCjh6eSToGNRMqW2VR8RrKEy+G+J7dFG7pKoptTH5T+XlKPleP9NY8JZYIpgJBlI+Osi0rFw==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.4.0 <1.10.0' + + '@opentelemetry/sdk-metrics@1.27.0': + resolution: {integrity: sha512-JzWgzlutoXCydhHWIbLg+r76m+m3ncqvkCcsswXAQ4gqKS+LOHKhq+t6fx1zNytvLuaOUBur7EvWxECc4jPQKg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.3.0 <1.10.0' + + '@opentelemetry/sdk-node@0.54.2': + resolution: {integrity: sha512-afn8GBpA7Gb55aU0LUxIQ+oe6QxLhsf+Te9iw12Non3ZAspzdoCcfz5+hqecwpuVpEDdnj5iSalF7VVaL2pDeg==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.3.0 <1.10.0' + + '@opentelemetry/sdk-trace-base@1.27.0': + resolution: {integrity: sha512-btz6XTQzwsyJjombpeqCX6LhiMQYpzt2pIYNPnw0IPO/3AhT6yjnf8Mnv3ZC2A4eRYOjqrg+bfaXg9XHDRJDWQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/sdk-trace-node@1.27.0': + resolution: {integrity: sha512-dWZp/dVGdUEfRBjBq2BgNuBlFqHCxyyMc8FsN0NX15X07mxSUO0SZRLyK/fdAVrde8nqFI/FEdMH4rgU9fqJfQ==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.10.0' + + '@opentelemetry/semantic-conventions@1.27.0': + resolution: {integrity: sha512-sAay1RrB+ONOem0OZanAR1ZI/k7yDpnOQSQmTMuGImUQb2y8EbSaCJ94FQluM74xoU03vlb2d2U90hZluL6nQg==} + engines: {node: '>=14'} + '@pkgjs/parseargs@0.11.0': resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==} engines: {node: '>=14'} @@ -2850,6 +3042,36 @@ packages: '@prefresh/utils@1.2.0': resolution: {integrity: sha512-KtC/fZw+oqtwOLUFM9UtiitB0JsVX0zLKNyRTA332sqREqSALIIQQxdUCS1P3xR/jT1e2e8/5rwH6gdcMLEmsQ==} + '@protobufjs/aspromise@1.1.2': + resolution: {integrity: sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ==} + + '@protobufjs/base64@1.1.2': + resolution: {integrity: sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==} + + '@protobufjs/codegen@2.0.4': + resolution: {integrity: sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==} + + '@protobufjs/eventemitter@1.1.0': + resolution: {integrity: sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q==} + + '@protobufjs/fetch@1.1.0': + resolution: {integrity: sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ==} + + '@protobufjs/float@1.0.2': + resolution: {integrity: sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ==} + + '@protobufjs/inquire@1.1.0': + resolution: {integrity: sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q==} + + '@protobufjs/path@1.1.2': + resolution: {integrity: sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA==} + + '@protobufjs/pool@1.1.0': + resolution: {integrity: sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw==} + + '@protobufjs/utf8@1.1.0': + resolution: {integrity: sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw==} + '@rc-component/async-validator@5.0.4': resolution: {integrity: sha512-qgGdcVIF604M9EqjNF0hbUTz42bz/RDtxWdWuU5EQe3hi7M8ob54B6B35rOsvX5eSvIHIzT9iH1R3n+hk3CGfg==} engines: {node: '>=14.x'} @@ -3613,6 +3835,9 @@ packages: '@types/serve-static@1.15.7': resolution: {integrity: sha512-W8Ym+h8nhuRwaKPaDw34QUkwsGi6Rc4yYqvKFo5rm2FUEhCFbzVWrxXUxuKK8TASjWsysJY0nsmNCGhCOIsrOw==} + '@types/shimmer@1.2.0': + resolution: {integrity: sha512-UE7oxhQLLd9gub6JKIAhDq06T0F6FnztwMNRvYgjeQSBeMc1ZG/tA47EwfduvkuQS8apbkM/lpLpWsaCeYsXVg==} + '@types/sockjs@0.3.36': resolution: {integrity: sha512-MK9V6NzAS1+Ud7JV9lJLFqW85VbC9dq3LmwZCuBe4wBDgKC0Kj/jd8Xl+nSviU+Qc3+m7umHHyHg//2KSa0a0Q==} @@ -5963,6 +6188,9 @@ packages: resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==} engines: {node: '>=6'} + import-in-the-middle@1.11.2: + resolution: {integrity: sha512-gK6Rr6EykBcc6cVWRSBR5TWf8nn6hZMYSRYqCcHa0l0d1fPK7JSYo6+Mlmck76jIX9aL/IZ71c06U2VpFwl1zA==} + import-lazy@4.0.0: resolution: {integrity: sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==} engines: {node: '>=8'} @@ -6652,6 +6880,9 @@ packages: lodash-es@4.17.21: resolution: {integrity: sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==} + lodash.camelcase@4.3.0: + resolution: {integrity: sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==} + lodash.memoize@4.1.2: resolution: {integrity: sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==} @@ -6668,6 +6899,9 @@ packages: resolution: {integrity: sha512-niTvB4gqvtof056rRIrTZvjNYE4rCUzO6X/X+kYjd7WFxXeJ0NwEFnRxX6ehkvv3jTwrXnNdtAak5XYZuIyPFw==} engines: {node: '>=18'} + long@5.2.3: + resolution: {integrity: sha512-lcHwpNoggQTObv5apGNCTdJrO69eHOZMi4BNC+rTLER8iHAqGrUVeLh/irVIM7zTw2bOXA8T6uNPeujwOLg/2Q==} + longest-streak@3.1.0: resolution: {integrity: sha512-9Ri+o0JYgehTaVBBDoMqIl8GXtbWg711O3srftcHhZ0dqnETqLaoIK0x17fUw9rFSlK/0NlsKe0Ahhyl5pXE2g==} @@ -7019,6 +7253,9 @@ packages: mlly@1.7.3: resolution: {integrity: sha512-xUsx5n/mN0uQf4V548PKQ+YShA4/IW0KI1dZhrNrPCLG+xizETbHTkOa1f8/xut9JRPp8kQuMnz0oqwkTiLo/A==} + module-details-from-path@1.0.3: + resolution: {integrity: sha512-ySViT69/76t8VhE1xXHK6Ch4NcDd26gx0MzKXLO+F7NOtnqH68d9zF94nT8ZWSxXh8ELOERsnJO/sWt1xZYw5A==} + monaco-editor-webpack-plugin@7.1.0: resolution: {integrity: sha512-ZjnGINHN963JQkFqjjcBtn1XBtUATDZBMgNQhDQwd78w2ukRhFXAPNgWuacaQiDZsUr4h1rWv5Mv6eriKuOSzA==} peerDependencies: @@ -7632,6 +7869,10 @@ packages: proto-list@1.2.4: resolution: {integrity: sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==} + protobufjs@7.4.0: + resolution: {integrity: sha512-mRUWCc3KUU4w1jU8sGxICXH/gNS94DvI1gxqDvBzhj1JpcsimQkYiOJfwsPUykUI5ZaspFbSgmBLER8IrQ3tqw==} + engines: {node: '>=12.0.0'} + proxy-addr@2.0.7: resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==} engines: {node: '>= 0.10'} @@ -8128,6 +8369,10 @@ packages: resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==} engines: {node: '>=0.10.0'} + require-in-the-middle@7.4.0: + resolution: {integrity: sha512-X34iHADNbNDfr6OTStIAHWSAvvKQRYgLO6duASaVf7J2VA3lvmNYboAHOuLC2huav1IwgZJtyEcJCKVzFxOSMQ==} + engines: {node: '>=8.6.0'} + requires-port@1.0.0: resolution: {integrity: sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==} @@ -8682,6 +8927,9 @@ packages: shell-quote@1.8.1: resolution: {integrity: sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==} + shimmer@1.2.1: + resolution: {integrity: sha512-sQTKC1Re/rM6XyFM6fIAGHRPVGvyXfgzIDvzoq608vM+jeyVD0Tu1E6Np0Kc2zAIFWIj963V2800iF/9LPieQw==} + side-channel@1.0.6: resolution: {integrity: sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==} engines: {node: '>= 0.4'} @@ -9866,6 +10114,10 @@ packages: resolution: {integrity: sha512-1/9UrdHjDZc0eOU0HxOHoS78C69UD3JRMvzlJ7S79S2nTaWRA/whGCTV8o9e/N/1Va9YIV7Q4sOxD8VV4pCWOw==} engines: {node: '>=12'} + yargs@17.7.2: + resolution: {integrity: sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==} + engines: {node: '>=12'} + yargs@3.10.0: resolution: {integrity: sha512-QFzUah88GAGy9lyDKGBqZdkYApt63rCXYBGYnEP4xDJPXNqXXnBDACnbrXnViV6jRSqAePwrATi2i8mfYm4L1A==} @@ -10726,6 +10978,18 @@ snapshots: '@fastify/busboy@2.1.1': {} + '@grpc/grpc-js@1.12.2': + dependencies: + '@grpc/proto-loader': 0.7.13 + '@js-sdsl/ordered-map': 4.4.2 + + '@grpc/proto-loader@0.7.13': + dependencies: + lodash.camelcase: 4.3.0 + long: 5.2.3 + protobufjs: 7.4.0 + yargs: 17.7.2 + '@gwhitney/detect-indent@7.0.1': {} '@iconify/types@2.0.0': {} @@ -11061,6 +11325,8 @@ snapshots: '@jridgewell/resolve-uri': 3.1.2 '@jridgewell/sourcemap-codec': 1.5.0 + '@js-sdsl/ordered-map@4.4.2': {} + '@jsonjoy.com/base64@1.1.2(tslib@2.8.0)': dependencies: tslib: 2.8.0 @@ -11519,6 +11785,208 @@ snapshots: dependencies: '@octokit/openapi-types': 22.2.0 + '@opentelemetry/api-logs@0.54.2': + dependencies: + '@opentelemetry/api': 1.9.0 + + '@opentelemetry/api@1.9.0': {} + + '@opentelemetry/context-async-hooks@1.26.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + + '@opentelemetry/context-async-hooks@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + + '@opentelemetry/core@1.26.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/semantic-conventions': 1.27.0 + + '@opentelemetry/core@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/semantic-conventions': 1.27.0 + + '@opentelemetry/exporter-logs-otlp-grpc@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@grpc/grpc-js': 1.12.2 + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-grpc-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-logs': 0.54.2(@opentelemetry/api@1.9.0) + + '@opentelemetry/exporter-logs-otlp-http@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/api-logs': 0.54.2 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-logs': 0.54.2(@opentelemetry/api@1.9.0) + + '@opentelemetry/exporter-logs-otlp-proto@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/api-logs': 0.54.2 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-logs': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/exporter-trace-otlp-grpc@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@grpc/grpc-js': 1.12.2 + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-grpc-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/exporter-trace-otlp-http@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/exporter-trace-otlp-proto@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/exporter-zipkin@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/semantic-conventions': 1.27.0 + + '@opentelemetry/instrumentation@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/api-logs': 0.54.2 + '@types/shimmer': 1.2.0 + import-in-the-middle: 1.11.2 + require-in-the-middle: 7.4.0 + semver: 7.6.3 + shimmer: 1.2.1 + transitivePeerDependencies: + - supports-color + + '@opentelemetry/otlp-exporter-base@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + + '@opentelemetry/otlp-grpc-exporter-base@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@grpc/grpc-js': 1.12.2 + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-exporter-base': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/otlp-transformer': 0.54.2(@opentelemetry/api@1.9.0) + + '@opentelemetry/otlp-transformer@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/api-logs': 0.54.2 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-logs': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-metrics': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + protobufjs: 7.4.0 + + '@opentelemetry/propagator-b3@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/propagator-jaeger@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/resources@1.26.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.26.0(@opentelemetry/api@1.9.0) + '@opentelemetry/semantic-conventions': 1.27.0 + + '@opentelemetry/resources@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/semantic-conventions': 1.27.0 + + '@opentelemetry/sdk-logs@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/api-logs': 0.54.2 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/sdk-metrics@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + + '@opentelemetry/sdk-node@0.54.2(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/api-logs': 0.54.2 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-logs-otlp-grpc': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-logs-otlp-http': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-logs-otlp-proto': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-trace-otlp-grpc': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-trace-otlp-http': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-trace-otlp-proto': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/exporter-zipkin': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/instrumentation': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-logs': 0.54.2(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-metrics': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-node': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/semantic-conventions': 1.27.0 + transitivePeerDependencies: + - supports-color + + '@opentelemetry/sdk-trace-base@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/resources': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/semantic-conventions': 1.27.0 + + '@opentelemetry/sdk-trace-node@1.27.0(@opentelemetry/api@1.9.0)': + dependencies: + '@opentelemetry/api': 1.9.0 + '@opentelemetry/context-async-hooks': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/core': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/propagator-b3': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/propagator-jaeger': 1.27.0(@opentelemetry/api@1.9.0) + '@opentelemetry/sdk-trace-base': 1.27.0(@opentelemetry/api@1.9.0) + semver: 7.6.3 + + '@opentelemetry/semantic-conventions@1.27.0': {} + '@pkgjs/parseargs@0.11.0': optional: true @@ -11768,6 +12236,29 @@ snapshots: '@prefresh/utils@1.2.0': {} + '@protobufjs/aspromise@1.1.2': {} + + '@protobufjs/base64@1.1.2': {} + + '@protobufjs/codegen@2.0.4': {} + + '@protobufjs/eventemitter@1.1.0': {} + + '@protobufjs/fetch@1.1.0': + dependencies: + '@protobufjs/aspromise': 1.1.2 + '@protobufjs/inquire': 1.1.0 + + '@protobufjs/float@1.0.2': {} + + '@protobufjs/inquire@1.1.0': {} + + '@protobufjs/path@1.1.2': {} + + '@protobufjs/pool@1.1.0': {} + + '@protobufjs/utf8@1.1.0': {} + '@rc-component/async-validator@5.0.4': dependencies: '@babel/runtime': 7.25.7 @@ -12642,6 +13133,8 @@ snapshots: '@types/node': 20.17.10 '@types/send': 0.17.4 + '@types/shimmer@1.2.0': {} + '@types/sockjs@0.3.36': dependencies: '@types/node': 20.17.10 @@ -12921,6 +13414,10 @@ snapshots: acorn: 8.11.3 acorn-walk: 8.3.2 + acorn-import-attributes@1.9.5(acorn@8.11.3): + dependencies: + acorn: 8.11.3 + acorn-import-attributes@1.9.5(acorn@8.14.0): dependencies: acorn: 8.14.0 @@ -15371,6 +15868,13 @@ snapshots: parent-module: 1.0.1 resolve-from: 4.0.0 + import-in-the-middle@1.11.2: + dependencies: + acorn: 8.11.3 + acorn-import-attributes: 1.9.5(acorn@8.11.3) + cjs-module-lexer: 1.2.3 + module-details-from-path: 1.0.3 + import-lazy@4.0.0: {} import-local@3.1.0: @@ -16241,6 +16745,8 @@ snapshots: lodash-es@4.17.21: {} + lodash.camelcase@4.3.0: {} + lodash.memoize@4.1.2: {} lodash.sortby@4.7.0: {} @@ -16257,6 +16763,8 @@ snapshots: strip-ansi: 7.1.0 wrap-ansi: 9.0.0 + long@5.2.3: {} + longest-streak@3.1.0: {} longest@1.0.1: {} @@ -16874,6 +17382,8 @@ snapshots: pkg-types: 1.2.1 ufo: 1.5.4 + module-details-from-path@1.0.3: {} + monaco-editor-webpack-plugin@7.1.0(monaco-editor@0.52.0)(webpack@5.95.0(@swc/core@1.10.1(@swc/helpers@0.5.15))(webpack-cli@5.1.4(webpack@5.95.0))): dependencies: loader-utils: 2.0.4 @@ -17420,6 +17930,21 @@ snapshots: proto-list@1.2.4: {} + protobufjs@7.4.0: + dependencies: + '@protobufjs/aspromise': 1.1.2 + '@protobufjs/base64': 1.1.2 + '@protobufjs/codegen': 2.0.4 + '@protobufjs/eventemitter': 1.1.0 + '@protobufjs/fetch': 1.1.0 + '@protobufjs/float': 1.0.2 + '@protobufjs/inquire': 1.1.0 + '@protobufjs/path': 1.1.2 + '@protobufjs/pool': 1.1.0 + '@protobufjs/utf8': 1.1.0 + '@types/node': 20.17.10 + long: 5.2.3 + proxy-addr@2.0.7: dependencies: forwarded: 0.2.0 @@ -18090,6 +18615,14 @@ snapshots: require-from-string@2.0.2: {} + require-in-the-middle@7.4.0: + dependencies: + debug: 4.3.7 + module-details-from-path: 1.0.3 + resolve: 1.22.8 + transitivePeerDependencies: + - supports-color + requires-port@1.0.0: {} resize-observer-polyfill@1.5.1: {} @@ -18598,6 +19131,8 @@ snapshots: shell-quote@1.8.1: {} + shimmer@1.2.1: {} + side-channel@1.0.6: dependencies: call-bind: 1.0.7 @@ -19979,6 +20514,16 @@ snapshots: y18n: 5.0.8 yargs-parser: 21.1.1 + yargs@17.7.2: + dependencies: + cliui: 8.0.1 + escalade: 3.2.0 + get-caller-file: 2.0.5 + require-directory: 2.1.1 + string-width: 4.2.3 + y18n: 5.0.8 + yargs-parser: 21.1.1 + yargs@3.10.0: dependencies: camelcase: 1.2.1