12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- package operation
- import (
- "context"
- "fmt"
- "io"
- "github.com/chrislusf/seaweedfs/weed/pb/volume_server_pb"
- "github.com/chrislusf/seaweedfs/weed/storage/needle"
- "google.golang.org/grpc"
- )
- func TailVolume(master string, grpcDialOption grpc.DialOption, vid needle.VolumeId, sinceNs uint64, timeoutSeconds int, fn func(n *needle.Needle) error) error {
- // find volume location, replication, ttl info
- lookup, err := Lookup(master, vid.String())
- if err != nil {
- return fmt.Errorf("look up volume %d: %v", vid, err)
- }
- if len(lookup.Locations) == 0 {
- return fmt.Errorf("unable to locate volume %d", vid)
- }
- volumeServer := lookup.Locations[0].Url
- return TailVolumeFromSource(volumeServer, grpcDialOption, vid, sinceNs, timeoutSeconds, fn)
- }
- func TailVolumeFromSource(volumeServer string, grpcDialOption grpc.DialOption, vid needle.VolumeId, sinceNs uint64, idleTimeoutSeconds int, fn func(n *needle.Needle) error) error {
- return WithVolumeServerClient(volumeServer, grpcDialOption, func(ctx context.Context, client volume_server_pb.VolumeServerClient) error {
- stream, err := client.VolumeTailSender(ctx, &volume_server_pb.VolumeTailSenderRequest{
- VolumeId: uint32(vid),
- SinceNs: sinceNs,
- IdleTimeoutSeconds: uint32(idleTimeoutSeconds),
- })
- if err != nil {
- return err
- }
- for {
- resp, recvErr := stream.Recv()
- if recvErr != nil {
- if recvErr == io.EOF {
- break
- } else {
- return recvErr
- }
- }
- needleHeader := resp.NeedleHeader
- needleBody := resp.NeedleBody
- if len(needleHeader) == 0 {
- continue
- }
- for !resp.IsLastChunk {
- resp, recvErr = stream.Recv()
- if recvErr != nil {
- if recvErr == io.EOF {
- break
- } else {
- return recvErr
- }
- }
- needleBody = append(needleBody, resp.NeedleBody...)
- }
- n := new(needle.Needle)
- n.ParseNeedleHeader(needleHeader)
- n.ReadNeedleBodyBytes(needleBody, needle.CurrentVersion)
- err = fn(n)
- if err != nil {
- return err
- }
- }
- return nil
- })
- }
|