From a7f73e060ac90901ccd64e095e3c28a2a4b3116d Mon Sep 17 00:00:00 2001 From: lbbniu Date: Mon, 8 Jan 2024 22:45:51 +0800 Subject: [PATCH] perf: optimize server-side handling of timeout control --- tars/transport/tarsserver.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/tars/transport/tarsserver.go b/tars/transport/tarsserver.go index 71a4d9fe..42b8b9ba 100755 --- a/tars/transport/tarsserver.go +++ b/tars/transport/tarsserver.go @@ -112,12 +112,12 @@ func (ts *TarsServer) invoke(ctx context.Context, pkg []byte) []byte { if cfg.HandleTimeout == 0 { rsp = ts.protocol.Invoke(ctx, pkg) } else { - invokeDone, cancelFunc := context.WithTimeout(context.Background(), cfg.HandleTimeout) + invokeCtx, cancelFunc := context.WithTimeout(ctx, cfg.HandleTimeout) go func() { - rsp = ts.protocol.Invoke(ctx, pkg) + rsp = ts.protocol.Invoke(invokeCtx, pkg) cancelFunc() }() - <-invokeDone.Done() + <-invokeCtx.Done() if len(rsp) == 0 { // The rsp must be none-empty rsp = ts.protocol.InvokeTimeout(pkg) }