|
@ -9,6 +9,7 @@ import ( |
|
|
"io" |
|
|
"io" |
|
|
"strings" |
|
|
"strings" |
|
|
"sync" |
|
|
"sync" |
|
|
|
|
|
"sync/atomic" |
|
|
"time" |
|
|
"time" |
|
|
|
|
|
|
|
|
"google.golang.org/grpc" |
|
|
"google.golang.org/grpc" |
|
@ -194,13 +195,13 @@ func (ma *MetaAggregator) doSubscribeToOneFiler(f *Filer, self pb.ServerAddress, |
|
|
err = pb.WithFilerClient(true, peer, ma.grpcDialOption, func(client filer_pb.SeaweedFilerClient) error { |
|
|
err = pb.WithFilerClient(true, peer, ma.grpcDialOption, func(client filer_pb.SeaweedFilerClient) error { |
|
|
ctx, cancel := context.WithCancel(context.Background()) |
|
|
ctx, cancel := context.WithCancel(context.Background()) |
|
|
defer cancel() |
|
|
defer cancel() |
|
|
ma.filer.UniqueFilerEpoch++ |
|
|
|
|
|
|
|
|
atomic.AddInt32(&ma.filer.UniqueFilerEpoch, 1) |
|
|
stream, err := client.SubscribeLocalMetadata(ctx, &filer_pb.SubscribeMetadataRequest{ |
|
|
stream, err := client.SubscribeLocalMetadata(ctx, &filer_pb.SubscribeMetadataRequest{ |
|
|
ClientName: "filer:" + string(self), |
|
|
ClientName: "filer:" + string(self), |
|
|
PathPrefix: "/", |
|
|
PathPrefix: "/", |
|
|
SinceNs: lastTsNs, |
|
|
SinceNs: lastTsNs, |
|
|
ClientId: ma.filer.UniqueFilerId, |
|
|
ClientId: ma.filer.UniqueFilerId, |
|
|
ClientEpoch: ma.filer.UniqueFilerEpoch, |
|
|
|
|
|
|
|
|
ClientEpoch: atomic.LoadInt32(&ma.filer.UniqueFilerEpoch), |
|
|
}) |
|
|
}) |
|
|
if err != nil { |
|
|
if err != nil { |
|
|
return fmt.Errorf("subscribe: %v", err) |
|
|
return fmt.Errorf("subscribe: %v", err) |
|
|