禁用 SIGHUP 信号的核心转储
Disable core dump for SIGHUP signal
我正在尝试禁用为我的应用程序中的各个信号生成的核心转储。
ulimit -c 0
在我的情况下不起作用,因为它需要在应用程序启动之前执行,并且将完全禁用所有信号的核心转储。
是否可以对单个信号进行此类例外处理或至少在一定时间内禁用核心转储生成(例如,在发送 SIGHUP 信号期间)?
#include <setjmp.h>
#include <signal.h>
#include <stdlib.h>
#include <sys/resource.h>
#include <unistd.h>
static sigjmp_buf sigjmp;
static void sighup_handler(int signo) {
siglongjmp(&sigjmp, signo);
}
int main(int argc, char **argv) {
struct sigaction sighup_action = {
.sa_handler = &sighup_handler,
.sa_flags = SA_RESETHAND,
};
sigset_t sigset;
int signo;
sigemptyset(&sighup_action.sa_mask);
sigaddset(&sighup_action.sa_mask, SIGHUP);
sigprocmask(SIG_BLOCK, &sighup_action.sa_mask, &sigset);
sigaction(SIGHUP, &sighup_action, NULL);
signo = sigsetjmp(&sigjmp, 1);
if (signo) {
struct rlimit rl = { .rlim_cur = 0, .rlim_max = 0 };
setrlimit(RLIMIT_CORE, &rl);
sigprocmask(SIG_SETMASK, &sigset, NULL);
kill(getpid(), signo);
abort(); /* just in case */
_exit(128 | signo);
}
sigprocmask(SIG_SETMASK, &sigset, NULL);
pause(); /* or whatever the rest of your program does */
}
您可以安装将 RLIMIT_CORE
设置为 0 的信号处理程序,然后继续执行默认信号操作。如果您使用 SA_RESETHAND
,默认信号处理程序会在信号处理程序 运行 之前自动重新安装。然而,setrlimit
不是异步信号安全的,所以我们不应该从信号处理程序内部调用它,因此使用 siglongjmp
到 return 到普通代码并在那里执行它。
只需为 SIGHUP 添加一个空的信号处理程序,或者像这样忽略它:
signal(SIGHUP, SIG_IGN);
我正在尝试禁用为我的应用程序中的各个信号生成的核心转储。
ulimit -c 0
在我的情况下不起作用,因为它需要在应用程序启动之前执行,并且将完全禁用所有信号的核心转储。
是否可以对单个信号进行此类例外处理或至少在一定时间内禁用核心转储生成(例如,在发送 SIGHUP 信号期间)?
#include <setjmp.h>
#include <signal.h>
#include <stdlib.h>
#include <sys/resource.h>
#include <unistd.h>
static sigjmp_buf sigjmp;
static void sighup_handler(int signo) {
siglongjmp(&sigjmp, signo);
}
int main(int argc, char **argv) {
struct sigaction sighup_action = {
.sa_handler = &sighup_handler,
.sa_flags = SA_RESETHAND,
};
sigset_t sigset;
int signo;
sigemptyset(&sighup_action.sa_mask);
sigaddset(&sighup_action.sa_mask, SIGHUP);
sigprocmask(SIG_BLOCK, &sighup_action.sa_mask, &sigset);
sigaction(SIGHUP, &sighup_action, NULL);
signo = sigsetjmp(&sigjmp, 1);
if (signo) {
struct rlimit rl = { .rlim_cur = 0, .rlim_max = 0 };
setrlimit(RLIMIT_CORE, &rl);
sigprocmask(SIG_SETMASK, &sigset, NULL);
kill(getpid(), signo);
abort(); /* just in case */
_exit(128 | signo);
}
sigprocmask(SIG_SETMASK, &sigset, NULL);
pause(); /* or whatever the rest of your program does */
}
您可以安装将 RLIMIT_CORE
设置为 0 的信号处理程序,然后继续执行默认信号操作。如果您使用 SA_RESETHAND
,默认信号处理程序会在信号处理程序 运行 之前自动重新安装。然而,setrlimit
不是异步信号安全的,所以我们不应该从信号处理程序内部调用它,因此使用 siglongjmp
到 return 到普通代码并在那里执行它。
只需为 SIGHUP 添加一个空的信号处理程序,或者像这样忽略它:
signal(SIGHUP, SIG_IGN);