harbor/src/pkg/exporter/cache.go

89 lines
1.5 KiB
Go
Raw Normal View History

package exporter
import (
"sync"
"time"
)
var c *cache
type cachedValue struct {
Value interface{}
Expiration int64
}
type cache struct {
CacheDuration int64
store map[string]cachedValue
*sync.RWMutex
}
// CacheGet get a value from cache
func CacheGet(key string) (value interface{}, ok bool) {
c.RLock()
v, ok := c.store[key]
c.RUnlock()
if !ok {
return nil, false
}
if time.Now().Unix() > v.Expiration {
c.Lock()
delete(c.store, key)
c.Unlock()
return nil, false
}
return v.Value, true
}
// CachePut put a value to cache with key
func CachePut(key, value interface{}) {
c.Lock()
defer c.Unlock()
c.store[key.(string)] = cachedValue{
Value: value,
Expiration: time.Now().Unix() + c.CacheDuration,
}
}
// CacheDelete delete a key from cache
func CacheDelete(key string) {
c.Lock()
defer c.Unlock()
delete(c.store, key)
}
// StartCacheCleaner start a cache clean job
func StartCacheCleaner() {
now := time.Now().UnixNano()
c.Lock()
defer c.Unlock()
for k, v := range c.store {
if v.Expiration < now {
delete(c.store, k)
}
}
}
// CacheEnabled returns if the cache in exporter enabled
func CacheEnabled() bool {
return c != nil
}
// CacheInit add cache to exporter
func CacheInit(opt *Opt) {
c = &cache{
CacheDuration: opt.CacheDuration,
store: make(map[string]cachedValue),
RWMutex: &sync.RWMutex{},
}
go func() {
ticker := time.NewTicker(time.Duration(opt.CacheCleanInterval) * time.Second)
for {
select {
case <-ticker.C:
StartCacheCleaner()
}
}
}()
}