2014-05-26 05:01:54 +08:00
|
|
|
package operation
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"strconv"
|
2016-06-14 05:34:05 +08:00
|
|
|
"sync"
|
2014-05-26 05:01:54 +08:00
|
|
|
"time"
|
2015-05-27 01:29:49 +08:00
|
|
|
|
2016-06-03 09:09:14 +08:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
2014-05-26 05:01:54 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type VidInfo struct {
|
|
|
|
Locations []Location
|
|
|
|
NextRefreshTime time.Time
|
|
|
|
}
|
|
|
|
type VidCache struct {
|
2016-06-14 05:34:05 +08:00
|
|
|
sync.RWMutex
|
2014-05-26 05:01:54 +08:00
|
|
|
cache []VidInfo
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vc *VidCache) Get(vid string) ([]Location, error) {
|
2015-05-27 01:29:49 +08:00
|
|
|
id, err := strconv.Atoi(vid)
|
|
|
|
if err != nil {
|
|
|
|
glog.V(1).Infof("Unknown volume id %s", vid)
|
|
|
|
return nil, err
|
|
|
|
}
|
2016-06-14 05:34:05 +08:00
|
|
|
vc.RLock()
|
|
|
|
defer vc.RUnlock()
|
2014-05-26 05:01:54 +08:00
|
|
|
if 0 < id && id <= len(vc.cache) {
|
|
|
|
if vc.cache[id-1].Locations == nil {
|
|
|
|
return nil, errors.New("Not Set")
|
|
|
|
}
|
|
|
|
if vc.cache[id-1].NextRefreshTime.Before(time.Now()) {
|
|
|
|
return nil, errors.New("Expired")
|
|
|
|
}
|
|
|
|
return vc.cache[id-1].Locations, nil
|
|
|
|
}
|
|
|
|
return nil, errors.New("Not Found")
|
|
|
|
}
|
|
|
|
func (vc *VidCache) Set(vid string, locations []Location, duration time.Duration) {
|
2015-05-27 01:29:49 +08:00
|
|
|
id, err := strconv.Atoi(vid)
|
|
|
|
if err != nil {
|
|
|
|
glog.V(1).Infof("Unknown volume id %s", vid)
|
|
|
|
return
|
|
|
|
}
|
2016-06-14 05:34:05 +08:00
|
|
|
vc.Lock()
|
|
|
|
defer vc.Unlock()
|
2015-05-27 01:29:49 +08:00
|
|
|
if id > len(vc.cache) {
|
2014-05-26 05:01:54 +08:00
|
|
|
for i := id - len(vc.cache); i > 0; i-- {
|
|
|
|
vc.cache = append(vc.cache, VidInfo{})
|
|
|
|
}
|
|
|
|
}
|
2015-05-27 01:29:49 +08:00
|
|
|
if id > 0 {
|
|
|
|
vc.cache[id-1].Locations = locations
|
|
|
|
vc.cache[id-1].NextRefreshTime = time.Now().Add(duration)
|
|
|
|
}
|
2014-05-26 05:01:54 +08:00
|
|
|
}
|