Browse Source

add lock for vidCache

pull/1560/head
Chris Lu 4 years ago
parent
commit
bd103c143a
  1. 5
      weed/filer/reader_at.go

5
weed/filer/reader_at.go

@ -38,9 +38,12 @@ type LookupFileIdFunctionType func(fileId string) (targetUrls []string, err erro
func LookupFn(filerClient filer_pb.FilerClient) LookupFileIdFunctionType { func LookupFn(filerClient filer_pb.FilerClient) LookupFileIdFunctionType {
vidCache := make(map[string]*filer_pb.Locations) vidCache := make(map[string]*filer_pb.Locations)
var vicCacheLock sync.RWMutex
return func(fileId string) (targetUrls []string, err error) { return func(fileId string) (targetUrls []string, err error) {
vid := VolumeId(fileId) vid := VolumeId(fileId)
vicCacheLock.RLock()
locations, found := vidCache[vid] locations, found := vidCache[vid]
vicCacheLock.RUnlock()
waitTime := time.Second waitTime := time.Second
for !found && waitTime < ReadWaitTime { for !found && waitTime < ReadWaitTime {
@ -58,7 +61,9 @@ func LookupFn(filerClient filer_pb.FilerClient) LookupFileIdFunctionType {
glog.V(0).Infof("failed to locate %s", fileId) glog.V(0).Infof("failed to locate %s", fileId)
return fmt.Errorf("failed to locate %s", fileId) return fmt.Errorf("failed to locate %s", fileId)
} }
vicCacheLock.Lock()
vidCache[vid] = locations vidCache[vid] = locations
vicCacheLock.Unlock()
return nil return nil
}) })

Loading…
Cancel
Save