prysm-pulse/slasher/cache/validators_cache.go
terence tsao 3edfa8cb88
Use Custom Type ValidatorIndex Across Prysm (#8478)
* Use ValidtorIndex across Prysm. Build ok

* First take at fixing tests

* Clean up e2e, fuzz... etc

* Fix new lines

* Update beacon-chain/cache/proposer_indices_test.go

Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>

* Update beacon-chain/core/helpers/rewards_penalties.go

Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>

* Update beacon-chain/core/helpers/shuffle.go

Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>

* Update validator/graffiti/parse_graffiti_test.go

Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>

* Raul's feedback

* Fix downcast int -> uint64

* Victor's feedback

Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>
Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
2021-02-23 00:14:50 +00:00

73 lines
2.2 KiB
Go

package cache
import (
lru "github.com/hashicorp/golang-lru"
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
types "github.com/prysmaticlabs/eth2-types"
)
var (
// validatorsCacheSize defines the max number of validators public keys the cache can hold.
validatorsCacheSize = 300000
// Metrics for the validator cache.
validatorsCacheHit = promauto.NewCounter(prometheus.CounterOpts{
Name: "validators_cache_hit",
Help: "The total number of cache hits on the validators cache.",
})
validatorsCacheMiss = promauto.NewCounter(prometheus.CounterOpts{
Name: "validators_cache_miss",
Help: "The total number of cache misses on the validators cache.",
})
)
// PublicKeyCache is used to store the public keys needed for signature verification.
type PublicKeyCache struct {
cache *lru.Cache
}
// NewPublicKeyCache initializes the cache.
func NewPublicKeyCache(size int, onEvicted func(key interface{}, value interface{})) (*PublicKeyCache, error) {
if size != 0 {
validatorsCacheSize = size
}
cache, err := lru.NewWithEvict(validatorsCacheSize, onEvicted)
if err != nil {
return nil, err
}
return &PublicKeyCache{cache: cache}, nil
}
// Get returns an ok bool and the cached value for the requested validator id key, if any.
func (c *PublicKeyCache) Get(validatorIdx types.ValidatorIndex) ([]byte, bool) {
item, exists := c.cache.Get(validatorIdx)
if exists && item != nil {
validatorsCacheHit.Inc()
return item.([]byte), true
}
validatorsCacheMiss.Inc()
return nil, false
}
// Set the response in the cache.
func (c *PublicKeyCache) Set(validatorIdx types.ValidatorIndex, publicKey []byte) {
_ = c.cache.Add(validatorIdx, publicKey)
}
// Delete removes a validator id from the cache and returns if it existed or not.
// Performs the onEviction function before removal.
func (c *PublicKeyCache) Delete(validatorIdx types.ValidatorIndex) bool {
return c.cache.Remove(validatorIdx)
}
// Has returns true if the key exists in the cache.
func (c *PublicKeyCache) Has(validatorIdx types.ValidatorIndex) bool {
return c.cache.Contains(validatorIdx)
}
// Clear removes all keys from the ValidatorCache.
func (c *PublicKeyCache) Clear() {
c.cache.Purge()
}