2020-04-02 03:08:23 +00:00
|
|
|
package cache
|
|
|
|
|
|
|
|
import (
|
|
|
|
lru "github.com/hashicorp/golang-lru"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
2021-02-23 00:14:50 +00:00
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
2021-09-02 10:36:54 +00:00
|
|
|
lruwrpr "github.com/prysmaticlabs/prysm/shared/lru"
|
2020-04-02 03:08:23 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
2021-09-02 10:36:54 +00:00
|
|
|
return &PublicKeyCache{cache: lruwrpr.NewWithEvict(validatorsCacheSize, onEvicted)}, nil
|
2020-04-02 03:08:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Get returns an ok bool and the cached value for the requested validator id key, if any.
|
2021-02-23 01:40:58 +00:00
|
|
|
func (c *PublicKeyCache) Get(validatorIndex types.ValidatorIndex) ([]byte, bool) {
|
|
|
|
item, exists := c.cache.Get(validatorIndex)
|
2020-04-02 03:08:23 +00:00
|
|
|
if exists && item != nil {
|
|
|
|
validatorsCacheHit.Inc()
|
|
|
|
return item.([]byte), true
|
|
|
|
}
|
|
|
|
|
|
|
|
validatorsCacheMiss.Inc()
|
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set the response in the cache.
|
2021-02-23 01:40:58 +00:00
|
|
|
func (c *PublicKeyCache) Set(validatorIndex types.ValidatorIndex, publicKey []byte) {
|
|
|
|
_ = c.cache.Add(validatorIndex, publicKey)
|
2020-04-02 03:08:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Delete removes a validator id from the cache and returns if it existed or not.
|
|
|
|
// Performs the onEviction function before removal.
|
2021-02-23 01:40:58 +00:00
|
|
|
func (c *PublicKeyCache) Delete(validatorIndex types.ValidatorIndex) bool {
|
|
|
|
return c.cache.Remove(validatorIndex)
|
2020-04-02 03:08:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Has returns true if the key exists in the cache.
|
2021-02-23 01:40:58 +00:00
|
|
|
func (c *PublicKeyCache) Has(validatorIndex types.ValidatorIndex) bool {
|
|
|
|
return c.cache.Contains(validatorIndex)
|
2020-04-02 03:08:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Clear removes all keys from the ValidatorCache.
|
|
|
|
func (c *PublicKeyCache) Clear() {
|
|
|
|
c.cache.Purge()
|
|
|
|
}
|