我有一个服务器应用程序,我想防止它被我可以忽略的任何信号停止。有没有办法一次忽略所有可能的信号,而不是一一设置?
问问题
17505 次
3 回答
16
是的:
#include <signal.h>
sigset_t mask;
sigfillset(&mask);
sigprocmask(SIG_SETMASK, &mask, NULL);
这不会完全忽略信号,而是阻止它们;这在实践中是相同的效果。
我想没有必要提及这一点SIGKILL
,SIGSTOP
也不能以任何方式被阻止或忽略。
有关更详细的语义,如掩码继承规则等,请查看手册页
于 2012-04-06T17:30:47.480 回答
14
阻塞信号与忽略它们不同。
当您按照 C2H5OH 的建议阻塞信号时,它会被添加到待处理的信号队列中,并在您解除阻塞后立即传递给进程。
解锁可以使用
#include <signal.h>
sigset_t mask;
sigemptyset(&mask);
sigprocmask(SIG_SETMASK, &mask, NULL);
要回答有关如何忽略信号的问题,它必须由 Signal Handler 处理,这是一个用户定义的函数,只要将信号传递给进程就会执行
static void foo (int bar)
{
/*some code here. In your case, nothing*/
}
然后使用注册此功能
signal(SIGINT,foo); //or whatever signal you want to ignore
如果你想忽略所有信号
int i;
for(i = 1; i <=31 ; i++)
{
signal(i,foo);
}
此代码将获取传递给进程的所有信号并忽略它们而不是阻止它们。
注意:根据手册页,这不是推荐的方式,而是建议使用 sigaction。签出man sigaction
于 2014-08-27T12:14:37.893 回答
5
基于我的解决方案sigprocmask()
但pthread_sigmask()
对我不起作用。这是我发现的工作:
#include <signal.h>
#include <unistd.h>
#include <assert.h>
int main() {
struct sigaction act;
act.sa_handler = SIG_IGN;
for(int i = 1 ; i < 65 ; i++) {
printf("i = %d\n", i);
// 9 and 19 cannot be caught or ignored
// 32 and 33 do not exist
if((i != SIGKILL) && (i != SIGSTOP) && (i != 32) && (i != 33)) {
assert(sigaction(i, &act, NULL) == 0);
}
}
sleep(10000);
return 0;
}
于 2015-04-03T14:36:08.300 回答