Browse Source

Add TODO explaining why the mutex storage is bad and what a better solution is

pull/44/head
Kegan Dougal 9 years ago
parent
commit
0e5716da1a
  1. 3
      src/github.com/matrix-org/go-neb/api.go

3
src/github.com/matrix-org/go-neb/api.go

@ -222,6 +222,9 @@ func (s *configureServiceHandler) getMutexForServiceID(serviceID string) *sync.M
defer s.mapMutex.Unlock() defer s.mapMutex.Unlock()
m := s.mutexByServiceID[serviceID] m := s.mutexByServiceID[serviceID]
if m == nil { if m == nil {
// XXX TODO: There's a memory leak here. The amount of mutexes created is unbounded, as there will be 1 per service which are never deleted.
// A better solution would be to have a striped hash map with a bounded pool of mutexes. We can't live with a single global mutex because the Register()
// function this is protecting does many many HTTP requests which can take a long time on bad networks and will head of line block other services.
m = &sync.Mutex{} m = &sync.Mutex{}
s.mutexByServiceID[serviceID] = m s.mutexByServiceID[serviceID] = m
} }

Loading…
Cancel
Save