correct grpc retry

This commit is contained in:
alex.sharov 2021-08-14 11:33:13 +07:00
parent 7fb2fa7edd
commit 72d47680cb

View File

@ -122,69 +122,71 @@ func (f *Fetch) receiveMessageLoop(sentryClient sentry.SentryClient) {
} }
_, err := sentryClient.SetStatus(f.ctx, f.statusData, grpc.WaitForReady(true)) _, err := sentryClient.SetStatus(f.ctx, f.statusData, grpc.WaitForReady(true))
if err != nil { if err != nil {
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled { s, ok := status.FromError(err)
return retryLater := (ok && s.Code() == codes.Canceled) || errors.Is(err, io.EOF) || errors.Is(err, context.Canceled)
if retryLater {
time.Sleep(time.Second)
continue
} }
// Report error and wait more // Report error and wait more
log.Warn("sentry not ready yet", "err", err) log.Warn("[txpool.recvMessage] sentry not ready yet", "err", err)
time.Sleep(time.Second)
continue continue
} }
streamCtx, cancel := context.WithCancel(f.ctx)
defer cancel()
stream, err := sentryClient.Messages(streamCtx, &sentry.MessagesRequest{Ids: []sentry.MessageId{ if err := f.receiveMessage(f.ctx, sentryClient); err != nil {
sentry.MessageId_NEW_POOLED_TRANSACTION_HASHES_65, s, ok := status.FromError(err)
sentry.MessageId_GET_POOLED_TRANSACTIONS_65, retryLater := (ok && s.Code() == codes.Canceled) || errors.Is(err, io.EOF) || errors.Is(err, context.Canceled)
sentry.MessageId_TRANSACTIONS_65, if retryLater {
sentry.MessageId_POOLED_TRANSACTIONS_65, time.Sleep(time.Second)
sentry.MessageId_NEW_POOLED_TRANSACTION_HASHES_66, continue
sentry.MessageId_GET_POOLED_TRANSACTIONS_66, }
sentry.MessageId_TRANSACTIONS_66,
sentry.MessageId_POOLED_TRANSACTIONS_66, log.Warn("[txpool.recvMessage]", "err", err)
}}, grpc.WaitForReady(true)) continue
}
}
}
func (f *Fetch) receiveMessage(ctx context.Context, sentryClient sentry.SentryClient) error {
streamCtx, cancel := context.WithCancel(ctx)
defer cancel()
stream, err := sentryClient.Messages(streamCtx, &sentry.MessagesRequest{Ids: []sentry.MessageId{
sentry.MessageId_NEW_POOLED_TRANSACTION_HASHES_65,
sentry.MessageId_GET_POOLED_TRANSACTIONS_65,
sentry.MessageId_TRANSACTIONS_65,
sentry.MessageId_POOLED_TRANSACTIONS_65,
sentry.MessageId_NEW_POOLED_TRANSACTION_HASHES_66,
sentry.MessageId_GET_POOLED_TRANSACTIONS_66,
sentry.MessageId_TRANSACTIONS_66,
sentry.MessageId_POOLED_TRANSACTIONS_66,
}}, grpc.WaitForReady(true))
if err != nil {
select {
case <-f.ctx.Done():
return ctx.Err()
default:
}
return err
}
var req *sentry.InboundMessage
for req, err = stream.Recv(); ; req, err = stream.Recv() {
if err != nil { if err != nil {
select { select {
case <-f.ctx.Done(): case <-f.ctx.Done():
return return ctx.Err()
default: default:
} }
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled { return err
return
}
if errors.Is(err, io.EOF) {
return
}
log.Warn("messages", "err", err)
return
} }
if req == nil {
var req *sentry.InboundMessage return nil
for req, err = stream.Recv(); ; req, err = stream.Recv() { }
if err != nil { if err = f.handleInboundMessage(streamCtx, req, sentryClient); err != nil {
select { log.Warn("Handling incoming message: %s", "err", err)
case <-f.ctx.Done(): }
return if f.wg != nil {
default: f.wg.Done()
}
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled {
return
}
if errors.Is(err, io.EOF) {
return
}
log.Warn("stream.Recv", "err", err)
return
}
if req == nil {
return
}
if err = f.handleInboundMessage(streamCtx, req, sentryClient); err != nil {
log.Warn("Handling incoming message: %s", "err", err)
}
if f.wg != nil {
f.wg.Done()
}
} }
} }
} }
@ -301,60 +303,58 @@ func (f *Fetch) receivePeerLoop(sentryClient sentry.SentryClient) {
} }
_, err := sentryClient.SetStatus(f.ctx, f.statusData, grpc.WaitForReady(true)) _, err := sentryClient.SetStatus(f.ctx, f.statusData, grpc.WaitForReady(true))
if err != nil { if err != nil {
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled { s, ok := status.FromError(err)
return retryLater := (ok && s.Code() == codes.Canceled) || errors.Is(err, io.EOF) || errors.Is(err, context.Canceled)
if retryLater {
time.Sleep(time.Second)
continue
} }
// Report error and wait more // Report error and wait more
log.Warn("sentry not ready yet", "err", err) log.Warn("[txpool.recvPeers] sentry not ready yet", "err", err)
time.Sleep(time.Second) time.Sleep(time.Second)
continue continue
} }
streamCtx, cancel := context.WithCancel(f.ctx) if err := f.receivePeer(sentryClient); err != nil {
defer cancel() s, ok := status.FromError(err)
retryLater := (ok && s.Code() == codes.Canceled) || errors.Is(err, io.EOF) || errors.Is(err, context.Canceled)
if retryLater {
time.Sleep(time.Second)
continue
}
stream, err := sentryClient.Peers(streamCtx, &sentry.PeersRequest{}) log.Warn("[txpool.recvPeers]", "err", err)
if err != nil {
select {
case <-f.ctx.Done():
return
default:
}
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled {
return
}
if errors.Is(err, io.EOF) {
return
}
log.Warn("peers", "err", err)
return return
} }
}
}
var req *sentry.PeersReply func (f *Fetch) receivePeer(sentryClient sentry.SentryClient) error {
for req, err = stream.Recv(); ; req, err = stream.Recv() { streamCtx, cancel := context.WithCancel(f.ctx)
if err != nil { defer cancel()
select {
case <-f.ctx.Done(): stream, err := sentryClient.Peers(streamCtx, &sentry.PeersRequest{})
return if err != nil {
default: select {
} case <-f.ctx.Done():
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled { return f.ctx.Err()
return default:
} }
if errors.Is(err, io.EOF) { return err
return }
}
log.Warn("stream.Recv", "err", err) var req *sentry.PeersReply
return for req, err = stream.Recv(); ; req, err = stream.Recv() {
} if err != nil {
if req == nil { return err
return }
} if req == nil {
if err = f.handleNewPeer(req); err != nil { return nil
log.Warn("Handling new peer", "err", err) }
} if err = f.handleNewPeer(req); err != nil {
if f.wg != nil { return err
f.wg.Done() }
} if f.wg != nil {
f.wg.Done()
} }
} }
} }
@ -381,10 +381,9 @@ func (f *Fetch) handleStateChanges(ctx context.Context, client remote.KVClient)
return return
default: default:
} }
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled { s, ok := status.FromError(err)
return terminated := (ok && s.Code() == codes.Canceled) || errors.Is(err, io.EOF)
} if terminated {
if errors.Is(err, io.EOF) {
return return
} }
time.Sleep(time.Second) time.Sleep(time.Second)
@ -397,10 +396,9 @@ func (f *Fetch) handleStateChanges(ctx context.Context, client remote.KVClient)
return return
default: default:
} }
if s, ok := status.FromError(err); ok && s.Code() == codes.Canceled { s, ok := status.FromError(err)
return terminated := (ok && s.Code() == codes.Canceled) || errors.Is(err, io.EOF)
} if terminated {
if errors.Is(err, io.EOF) {
return return
} }
log.Warn("stream.Recv", "err", err) log.Warn("stream.Recv", "err", err)