Skip to content

Commit

Permalink
tracing: instrument contract cache operations (#10777)
Browse files Browse the repository at this point in the history
This instruments the `StoreCompiledContractCache` to show an overall
cost of these operations whenever they are used. The level I've chosen
here is `trace` to avoid polluting the traces too much in default
operation. #10774 has a targeted instrumentation at a higher level.
  • Loading branch information
nagisa authored and VanBarbascu committed Mar 26, 2024
1 parent aac5e42 commit ebeea52
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 0 deletions.
14 changes: 14 additions & 0 deletions core/store/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -893,6 +893,13 @@ impl StoreCompiledContractCache {
/// Key must take into account VM being used and its configuration, so that
/// we don't cache non-gas metered binaries, for example.
impl CompiledContractCache for StoreCompiledContractCache {
#[tracing::instrument(
level = "trace",
target = "store",
"StoreCompiledContractCache::put",
skip_all,
fields(key = key.to_string(), value.len = value.debug_len()),
)]
fn put(&self, key: &CryptoHash, value: CompiledContract) -> io::Result<()> {
let mut update = crate::db::DBTransaction::new();
// We intentionally use `.set` here, rather than `.insert`. We don't yet
Expand All @@ -907,6 +914,13 @@ impl CompiledContractCache for StoreCompiledContractCache {
self.db.write(update)
}

#[tracing::instrument(
level = "trace",
target = "store",
"StoreCompiledContractCache::get",
skip_all,
fields(key = key.to_string()),
)]
fn get(&self, key: &CryptoHash) -> io::Result<Option<CompiledContract>> {
match self.db.get_raw_bytes(DBCol::CachedContractCode, key.as_ref()) {
Ok(Some(bytes)) => Ok(Some(CompiledContract::try_from_slice(&bytes)?)),
Expand Down
12 changes: 12 additions & 0 deletions runtime/near-vm-runner/src/logic/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,18 @@ pub enum CompiledContract {
Code(Vec<u8>),
}

impl CompiledContract {
/// Return the length of the compiled contract data.
///
/// If the `CompiledContract` represents a compilation failure, returns `0`.
pub fn debug_len(&self) -> usize {
match self {
CompiledContract::CompileModuleError(_) => 0,
CompiledContract::Code(c) => c.len(),
}
}
}

/// Cache for compiled modules
pub trait CompiledContractCache: Send + Sync {
fn put(&self, key: &CryptoHash, value: CompiledContract) -> std::io::Result<()>;
Expand Down

0 comments on commit ebeea52

Please sign in to comment.