mirror of
https://github.com/denoland/deno.git
synced 2025-01-03 04:48:52 -05:00
perf: disable runtime snapshot compression (#18239)
This commit removes compression for the runtime JS code.
It means that we will have a bigger binary, but faster startup. After
several discussion in the CLI team we decided it's worth to trade
about 3Mb of binary size for 2ms faster startup time. With WebGPU
removed in 35196eab27
it shouldn't have such a big impact on the binary size.
This commit is contained in:
parent
35196eab27
commit
8f9becee76
8 changed files with 7 additions and 92 deletions
11
Cargo.lock
generated
11
Cargo.lock
generated
|
@ -750,7 +750,6 @@ dependencies = [
|
||||||
"libc",
|
"libc",
|
||||||
"log",
|
"log",
|
||||||
"lsp-types",
|
"lsp-types",
|
||||||
"lzzzz",
|
|
||||||
"mitata",
|
"mitata",
|
||||||
"monch",
|
"monch",
|
||||||
"napi_sym",
|
"napi_sym",
|
||||||
|
@ -1207,7 +1206,6 @@ dependencies = [
|
||||||
"hyper",
|
"hyper",
|
||||||
"libc",
|
"libc",
|
||||||
"log",
|
"log",
|
||||||
"lzzzz",
|
|
||||||
"netif",
|
"netif",
|
||||||
"nix",
|
"nix",
|
||||||
"notify",
|
"notify",
|
||||||
|
@ -2598,15 +2596,6 @@ dependencies = [
|
||||||
"url",
|
"url",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "lzzzz"
|
|
||||||
version = "1.0.4"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "8014d1362004776e6a91e4c15a3aa7830d1b6650a075b51a9969ebb6d6af13bc"
|
|
||||||
dependencies = [
|
|
||||||
"cc",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "match_cfg"
|
name = "match_cfg"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
|
|
@ -97,7 +97,6 @@ indexmap = { version = "1.9.2", features = ["serde"] }
|
||||||
libc = "0.2.126"
|
libc = "0.2.126"
|
||||||
log = "=0.4.17"
|
log = "=0.4.17"
|
||||||
lsp-types = "=0.93.2" # used by tower-lsp and "proposed" feature is unstable in patch releases
|
lsp-types = "=0.93.2" # used by tower-lsp and "proposed" feature is unstable in patch releases
|
||||||
lzzzz = "1.0"
|
|
||||||
notify = "=5.0.0"
|
notify = "=5.0.0"
|
||||||
num-bigint = "0.4"
|
num-bigint = "0.4"
|
||||||
once_cell = "1.17.1"
|
once_cell = "1.17.1"
|
||||||
|
@ -232,8 +231,6 @@ opt-level = 3
|
||||||
opt-level = 3
|
opt-level = 3
|
||||||
[profile.bench.package.zstd]
|
[profile.bench.package.zstd]
|
||||||
opt-level = 3
|
opt-level = 3
|
||||||
[profile.bench.package.lzzzz]
|
|
||||||
opt-level = 3
|
|
||||||
[profile.bench.package.zstd-sys]
|
[profile.bench.package.zstd-sys]
|
||||||
opt-level = 3
|
opt-level = 3
|
||||||
[profile.bench.package.base64-simd]
|
[profile.bench.package.base64-simd]
|
||||||
|
@ -306,8 +303,6 @@ opt-level = 3
|
||||||
opt-level = 3
|
opt-level = 3
|
||||||
[profile.release.package.zstd]
|
[profile.release.package.zstd]
|
||||||
opt-level = 3
|
opt-level = 3
|
||||||
[profile.release.package.lzzzz]
|
|
||||||
opt-level = 3
|
|
||||||
[profile.release.package.zstd-sys]
|
[profile.release.package.zstd-sys]
|
||||||
opt-level = 3
|
opt-level = 3
|
||||||
[profile.release.package.base64-simd]
|
[profile.release.package.base64-simd]
|
||||||
|
|
|
@ -35,8 +35,6 @@ serde_json.workspace = true
|
||||||
zstd.workspace = true
|
zstd.workspace = true
|
||||||
glibc_version = "0.1.2"
|
glibc_version = "0.1.2"
|
||||||
|
|
||||||
lzzzz = '1.0'
|
|
||||||
|
|
||||||
[target.'cfg(windows)'.build-dependencies]
|
[target.'cfg(windows)'.build-dependencies]
|
||||||
winapi.workspace = true
|
winapi.workspace = true
|
||||||
winres.workspace = true
|
winres.workspace = true
|
||||||
|
@ -81,7 +79,6 @@ jsonc-parser = { version = "=0.21.0", features = ["serde"] }
|
||||||
libc.workspace = true
|
libc.workspace = true
|
||||||
log = { workspace = true, features = ["serde"] }
|
log = { workspace = true, features = ["serde"] }
|
||||||
lsp-types.workspace = true
|
lsp-types.workspace = true
|
||||||
lzzzz = '1.0'
|
|
||||||
mitata = "=0.0.7"
|
mitata = "=0.0.7"
|
||||||
monch = "=0.4.1"
|
monch = "=0.4.1"
|
||||||
notify.workspace = true
|
notify.workspace = true
|
||||||
|
|
|
@ -364,14 +364,7 @@ fn create_cli_snapshot(snapshot_path: PathBuf) {
|
||||||
snapshot_path,
|
snapshot_path,
|
||||||
startup_snapshot: Some(deno_runtime::js::deno_isolate_init()),
|
startup_snapshot: Some(deno_runtime::js::deno_isolate_init()),
|
||||||
extensions,
|
extensions,
|
||||||
compression_cb: Some(Box::new(|vec, snapshot_slice| {
|
compression_cb: None,
|
||||||
lzzzz::lz4_hc::compress_to_vec(
|
|
||||||
snapshot_slice,
|
|
||||||
vec,
|
|
||||||
lzzzz::lz4_hc::CLEVEL_MAX,
|
|
||||||
)
|
|
||||||
.expect("snapshot compression failed");
|
|
||||||
})),
|
|
||||||
snapshot_module_load_cb: None,
|
snapshot_module_load_cb: None,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
29
cli/js.rs
29
cli/js.rs
|
@ -2,36 +2,13 @@
|
||||||
|
|
||||||
use deno_core::Snapshot;
|
use deno_core::Snapshot;
|
||||||
use log::debug;
|
use log::debug;
|
||||||
use once_cell::sync::Lazy;
|
|
||||||
|
|
||||||
pub static CLI_SNAPSHOT: Lazy<Box<[u8]>> = Lazy::new(
|
static CLI_SNAPSHOT: &[u8] =
|
||||||
#[allow(clippy::uninit_vec)]
|
include_bytes!(concat!(env!("OUT_DIR"), "/CLI_SNAPSHOT.bin"));
|
||||||
#[cold]
|
|
||||||
#[inline(never)]
|
|
||||||
|| {
|
|
||||||
static COMPRESSED_CLI_SNAPSHOT: &[u8] =
|
|
||||||
include_bytes!(concat!(env!("OUT_DIR"), "/CLI_SNAPSHOT.bin"));
|
|
||||||
|
|
||||||
let size =
|
|
||||||
u32::from_le_bytes(COMPRESSED_CLI_SNAPSHOT[0..4].try_into().unwrap())
|
|
||||||
as usize;
|
|
||||||
let mut vec = Vec::with_capacity(size);
|
|
||||||
|
|
||||||
// SAFETY: vec is allocated with exact snapshot size (+ alignment)
|
|
||||||
// SAFETY: non zeroed bytes are overwritten with decompressed snapshot
|
|
||||||
unsafe {
|
|
||||||
vec.set_len(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
lzzzz::lz4::decompress(&COMPRESSED_CLI_SNAPSHOT[4..], &mut vec).unwrap();
|
|
||||||
|
|
||||||
vec.into_boxed_slice()
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
pub fn deno_isolate_init() -> Snapshot {
|
pub fn deno_isolate_init() -> Snapshot {
|
||||||
debug!("Deno isolate init with snapshots.");
|
debug!("Deno isolate init with snapshots.");
|
||||||
Snapshot::Static(&CLI_SNAPSHOT)
|
Snapshot::Static(CLI_SNAPSHOT)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
|
|
@ -55,8 +55,6 @@ deno_websocket.workspace = true
|
||||||
deno_webstorage.workspace = true
|
deno_webstorage.workspace = true
|
||||||
deno_napi.workspace = true
|
deno_napi.workspace = true
|
||||||
|
|
||||||
lzzzz.workspace = true
|
|
||||||
|
|
||||||
[target.'cfg(windows)'.build-dependencies]
|
[target.'cfg(windows)'.build-dependencies]
|
||||||
winres.workspace = true
|
winres.workspace = true
|
||||||
winapi.workspace = true
|
winapi.workspace = true
|
||||||
|
@ -93,7 +91,6 @@ http.workspace = true
|
||||||
hyper = { workspace = true, features = ["server", "stream", "http1", "http2", "runtime"] }
|
hyper = { workspace = true, features = ["server", "stream", "http1", "http2", "runtime"] }
|
||||||
libc.workspace = true
|
libc.workspace = true
|
||||||
log.workspace = true
|
log.workspace = true
|
||||||
lzzzz.workspace = true
|
|
||||||
netif = "0.1.6"
|
netif = "0.1.6"
|
||||||
notify.workspace = true
|
notify.workspace = true
|
||||||
once_cell.workspace = true
|
once_cell.workspace = true
|
||||||
|
|
|
@ -299,14 +299,7 @@ mod startup_snapshot {
|
||||||
snapshot_path,
|
snapshot_path,
|
||||||
startup_snapshot: None,
|
startup_snapshot: None,
|
||||||
extensions,
|
extensions,
|
||||||
compression_cb: Some(Box::new(|vec, snapshot_slice| {
|
compression_cb: None,
|
||||||
lzzzz::lz4_hc::compress_to_vec(
|
|
||||||
snapshot_slice,
|
|
||||||
vec,
|
|
||||||
lzzzz::lz4_hc::CLEVEL_MAX,
|
|
||||||
)
|
|
||||||
.expect("snapshot compression failed");
|
|
||||||
})),
|
|
||||||
snapshot_module_load_cb: Some(Box::new(transpile_ts_for_snapshotting)),
|
snapshot_module_load_cb: Some(Box::new(transpile_ts_for_snapshotting)),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,41 +3,15 @@
|
||||||
use deno_core::Snapshot;
|
use deno_core::Snapshot;
|
||||||
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
||||||
use log::debug;
|
use log::debug;
|
||||||
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
|
||||||
use once_cell::sync::Lazy;
|
|
||||||
|
|
||||||
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
||||||
static COMPRESSED_RUNTIME_SNAPSHOT: &[u8] =
|
static RUNTIME_SNAPSHOT: &[u8] =
|
||||||
include_bytes!(concat!(env!("OUT_DIR"), "/RUNTIME_SNAPSHOT.bin"));
|
include_bytes!(concat!(env!("OUT_DIR"), "/RUNTIME_SNAPSHOT.bin"));
|
||||||
|
|
||||||
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
|
||||||
pub static RUNTIME_SNAPSHOT: Lazy<Box<[u8]>> = Lazy::new(
|
|
||||||
#[allow(clippy::uninit_vec)]
|
|
||||||
#[cold]
|
|
||||||
#[inline(never)]
|
|
||||||
|| {
|
|
||||||
let size =
|
|
||||||
u32::from_le_bytes(COMPRESSED_RUNTIME_SNAPSHOT[0..4].try_into().unwrap())
|
|
||||||
as usize;
|
|
||||||
let mut vec = Vec::with_capacity(size);
|
|
||||||
|
|
||||||
// SAFETY: vec is allocated with exact snapshot size (+ alignment)
|
|
||||||
// SAFETY: non zeroed bytes are overwritten with decompressed snapshot
|
|
||||||
unsafe {
|
|
||||||
vec.set_len(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
lzzzz::lz4::decompress(&COMPRESSED_RUNTIME_SNAPSHOT[4..], &mut vec)
|
|
||||||
.unwrap();
|
|
||||||
|
|
||||||
vec.into_boxed_slice()
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
#[cfg(not(feature = "dont_create_runtime_snapshot"))]
|
||||||
pub fn deno_isolate_init() -> Snapshot {
|
pub fn deno_isolate_init() -> Snapshot {
|
||||||
debug!("Deno isolate init with snapshots.");
|
debug!("Deno isolate init with snapshots.");
|
||||||
Snapshot::Static(&RUNTIME_SNAPSHOT)
|
Snapshot::Static(RUNTIME_SNAPSHOT)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(feature = "include_js_files_for_snapshotting"))]
|
#[cfg(not(feature = "include_js_files_for_snapshotting"))]
|
||||||
|
|
Loading…
Reference in a new issue