diff options
author | Péter Szilágyi <peterke@gmail.com> | 2016-10-19 19:29:24 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-10-19 19:29:24 +0800 |
commit | 8e52c2e754cdb343d0eb880a33251e1ba593d327 (patch) | |
tree | 1435066b5021fa49d7d16558440ac8ccfd3a6831 /trie/trie.go | |
parent | c9471e778209e16442a530820fb90c01cd47c369 (diff) | |
parent | 2bb5ec1e41ed8c1e56e31639fec87710e81d3977 (diff) | |
download | go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.tar go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.tar.gz go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.tar.bz2 go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.tar.lz go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.tar.xz go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.tar.zst go-tangerine-8e52c2e754cdb343d0eb880a33251e1ba593d327.zip |
Merge pull request #3161 from karalabe/trie-cache-counters
cmd/geth, trie: track and report trie cache misses
Diffstat (limited to 'trie/trie.go')
-rw-r--r-- | trie/trie.go | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/trie/trie.go b/trie/trie.go index 65005bae8..5a4b6185d 100644 --- a/trie/trie.go +++ b/trie/trie.go @@ -20,6 +20,7 @@ package trie import ( "bytes" "fmt" + "sync/atomic" "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/crypto/sha3" @@ -34,6 +35,17 @@ var ( emptyState common.Hash ) +// cacheMisses maintains the number of times a trie node was loaded from disk. +// Always use atomic operations when accessing this global variable. +var cacheMisses uint64 + +// CacheMisses retrieves a global counter measuring the number of cache misses +// the trie did since process startup. This isn't useful for anything apart from +// trie debugging purposes. +func CacheMisses() uint64 { + return atomic.LoadUint64(&cacheMisses) +} + func init() { sha3.NewKeccak256().Sum(emptyState[:0]) } @@ -419,6 +431,8 @@ func (t *Trie) resolve(n node, prefix, suffix []byte) (node, error) { } func (t *Trie) resolveHash(n hashNode, prefix, suffix []byte) (node, error) { + atomic.AddUint64(&cacheMisses, 1) + enc, err := t.db.Get(n) if err != nil || enc == nil { return nil, &MissingNodeError{ |