diff options
| author | chrislu <chris.lu@gmail.com> | 2024-06-13 21:48:44 -0700 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2024-06-13 21:48:44 -0700 |
| commit | b03c831ad24d67f6dc429c13d7ce07142320a0ac (patch) | |
| tree | 1559269dbf00b3aa4075c0098c8389368ae67103 /weed | |
| parent | e6b9b6ade7de421bdc36b61577590ee6a6ebefd0 (diff) | |
| download | seaweedfs-b03c831ad24d67f6dc429c13d7ce07142320a0ac.tar.xz seaweedfs-b03c831ad24d67f6dc429c13d7ce07142320a0ac.zip | |
more logs
Diffstat (limited to 'weed')
| -rw-r--r-- | weed/server/filer_grpc_server_sub_meta.go | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/weed/server/filer_grpc_server_sub_meta.go b/weed/server/filer_grpc_server_sub_meta.go index 436c4158f..5deb9d7ca 100644 --- a/weed/server/filer_grpc_server_sub_meta.go +++ b/weed/server/filer_grpc_server_sub_meta.go @@ -31,7 +31,11 @@ func (fs *FilerServer) SubscribeMetadata(req *filer_pb.SubscribeMetadataRequest, } else if alreadyKnown { return fmt.Errorf("duplicated subscription detected for client %s id %d", clientName, req.ClientId) } - defer fs.deleteClient("", clientName, req.ClientId, req.ClientEpoch) + defer func() { + glog.V(0).Infof("disconnect %v subscriber %s clientId:%d", clientName, req.PathPrefix, req.ClientId) + fs.deleteClient("", clientName, req.ClientId, req.ClientEpoch) + fs.filer.MetaAggregator.ListenersCond.Broadcast() // nudges the subscribers that are waiting + }() lastReadTime := log_buffer.NewMessagePosition(req.SinceNs, -2) glog.V(0).Infof(" %v starts to subscribe %s from %+v", clientName, req.PathPrefix, lastReadTime) @@ -112,6 +116,7 @@ func (fs *FilerServer) SubscribeLocalMetadata(req *filer_pb.SubscribeMetadataReq defer func() { glog.V(0).Infof("disconnect %v local subscriber %s clientId:%d", clientName, req.PathPrefix, req.ClientId) fs.deleteClient("local", clientName, req.ClientId, req.ClientEpoch) + fs.listenersCond.Broadcast() // nudges the subscribers that are waiting }() lastReadTime := log_buffer.NewMessagePosition(req.SinceNs, -2) |
