GRPC服务器关闭永久挂起

gRPC Server shutdown hangs forever(GRPC服务器关闭永久挂起)
本文介绍了GRPC服务器关闭永久挂起的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

您好,我有一个用C++编写的GRPC异步服务器。

我正在接收AsyncNext的RPC,该RPC正在破坏它自己的线程,目前它的截止日期是16毫秒。

我正在使用建议的关闭程序

Server->Shutdown();
Que->Shutdown();
DrainQue();
在正常情况下,一切正常,但当客户端在关机前发送RPC,并且继续发送且从不停止时, AsyncNext在客户端停止发送之前从不结束。这将挂起进程,即使它已关闭&q;。

如果正常关闭不成功,我想在任何状态下终止GRPC服务器。由于不停止该进程,会导致出现大量未解决的问题。

编辑:我使用的是gPRC 1.40.x版和Windows 10作为平台

推荐答案

原来请求可以用Context.TryCancel();取消,正在进行的RPC可以用Responder.FinishWithError(grpc::Status::CANCELLED, this);结束

我也没有使用AsyncNotifyWhenDone

这篇关于GRPC服务器关闭永久挂起的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

socks4 with asynchronous boost::asio(带有异步Boost::ASIO的socks4)
Boost ASIO HTTP client POST(增强ASIO HTTP客户端开机自检)
asio::strandlt;asio::io_context::executor_typegt; vs io_context::strand(Asio::strandlt;asio::io_context::executor_typegt;VS io_CONTEXT::Strand)
What#39;s the difference between asio::io_context and asio::thread_pool?(ASIO::IO_CONTEXT和ASIO::THREAD_POOL有什么区别?)
How to use boost::asio with Linux GPIOs(如何在Linux GPIO中使用Boost::ASIO)
Boost asio io_service vs io_context(增强ASIO io_服务与io_Context)