Просмотр исходного кода

Merge pull request #10974 from lzhfromustc/watchers

proxy: Add critical section to protect wps.watchers and wps.nextWatcherID
Xiang Li 6 лет назад
Родитель
Сommit
bbb379fa4a
1 измененных файлов с 2 добавлено и 0 удалено
  1. 2 0
      proxy/grpcproxy/watch.go

+ 2 - 0
proxy/grpcproxy/watch.go

@@ -241,6 +241,7 @@ func (wps *watchProxyStream) recvLoop() error {
 				continue
 			}
 
+			wps.mu.Lock()
 			w := &watcher{
 				wr:  watchRange{string(cr.Key), string(cr.RangeEnd)},
 				id:  wps.nextWatcherID,
@@ -259,6 +260,7 @@ func (wps *watchProxyStream) recvLoop() error {
 			w.nextrev = cr.StartRevision
 			wps.watchers[w.id] = w
 			wps.ranges.add(w)
+			wps.mu.Unlock()
 		case *pb.WatchRequest_CancelRequest:
 			wps.delete(uv.CancelRequest.WatchId)
 		default: