Skip to content
Snippets Groups Projects
Commit 6e34c3bb authored by ensiouel's avatar ensiouel
Browse files

refactor: убрана обертка для сбора метрик кэша

parent c8093a14
No related branches found
No related tags found
No related merge requests found
package cache
import (
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
)
var (
cacheHitsTotal = promauto.With(prometheus.DefaultRegisterer).NewCounterVec(prometheus.CounterOpts{
Name: "cache_hits_total",
Help: "Количество попаданий в кэш.",
}, []string{"cache_id"})
cacheMissesTotal = promauto.With(prometheus.DefaultRegisterer).NewCounterVec(prometheus.CounterOpts{
Name: "cache_misses_total",
Help: "Количество пропусков в кэш.",
}, []string{"cache_id"})
)
type metricsCache struct {
cache Cache
cacheID string
}
// WithMetrics возвращает обертку над кэшем, которая используется для отслеживания количества хитов и промахов в кэше.
// Помимо этого, в функцию WithMetrics передается параметр cacheID, который используется в метке метрик для идентификации конкретного кэша.
//
// Метрики записываются в prometheus.DefaultRegisterer
func WithMetrics(cache Cache, cacheID string) Cache {
if cache == nil {
panic("cannot wrap metrics in cache, cache is nil")
}
return &metricsCache{
cacheID: cacheID,
cache: cache,
}
}
func (c *metricsCache) Set(key, value any) error {
return c.cache.Set(key, value)
}
func (c *metricsCache) Get(key any) (any, error) {
value, err := c.cache.Get(key)
if err != nil {
cacheMissesTotal.WithLabelValues(c.cacheID).Inc()
return nil, err
}
cacheHitsTotal.WithLabelValues(c.cacheID).Inc()
return value, nil
}
func (c *metricsCache) Remove(key any) error {
return c.cache.Remove(key)
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment