如果前端 Tomcat 被杀死,C++ 服务器将终止。错误“收到未捕获的信号 [13] - SIGPIPE”

Posted

技术标签:

【中文标题】如果前端 Tomcat 被杀死,C++ 服务器将终止。错误“收到未捕获的信号 [13] - SIGPIPE”【英文标题】:C++ Server is terminating if the front end Tomcat is killed. Error "Received untrapped signal [13] - SIGPIPE" 【发布时间】:2009-11-12 06:20:21 【问题描述】:

我的 C++ 服务器程序遇到问题。请求 XML 来自前端 (Java),后端服务器 (C++) 处理请求并返回回复 XML。

作为向后端提交请求后测试的一部分,我们终止了 Tomcat 服务器。处理请求后的后端应用程序(线程服务器应用程序)未能发送响应,因为 Tomcat 服务器已关闭。服务器通过抛出错误“received untrapped signal [13] - [SIGPIPE]”终止。我们已经实现了 sigalrm 和 sigterm 函数。

上述信号错误未被捕获。实施 sigaction 会有帮助吗?此外,一旦捕获到信号,需要做什么才能返回到服务器正在侦听的主循环?

编辑:

我们发现 send() 函数有一个参数 MSG_NOSIGNAL。在传递此参数时,如果连接终止,发送函数将不会抛出 SIGPIPE 信号。

【问题讨论】:

【参考方案1】:

最简单的做法就是忽略信号:

struct sigaction new_action, old_action;

/* Set up the structure to specify the new action. */
new_action.sa_handler = SIG_IGN;
sigemptyset (&new_action.sa_mask);
new_action.sa_flags = 0;

sigaction(SIGPIPE, &new_action, &old_action);

执行此操作后,导致信号的读取或写入调用现在将返回错误,您的代码需要准备好处理该问题。

【讨论】:

以上是关于如果前端 Tomcat 被杀死,C++ 服务器将终止。错误“收到未捕获的信号 [13] - SIGPIPE”的主要内容,如果未能解决你的问题,请参考以下文章

jenkins中通过execute shell启动的进程会被杀死的问题

powershell 杀死IntelliJ java进程(在IntelliJ中停止Tomcat调试会话时,某些进程未被杀死并保持阻塞端口1099)

powershell 杀死IntelliJ java进程(在IntelliJ中停止Tomcat调试会话时,某些进程未被杀死并保持阻塞端口1099)

tomcat服务器莫名其妙重启137 143

杀死tomcat进程

AWS ecs - 如果其中一个容器退出或被杀死,所有容器都会被杀死(停止)