我试图守护一个进程,并发现我们应该将它分给它两次。原因是如果这个过程是一个会话领导者,那么它就可以控制tty。我在想,这个理论的理论基础是什么?
发布于 2013-12-26 14:33:11
第一个叉子是在单独的会话中运行守护进程。您需要做的是去守护(伪代码):
fork()
if (parent) {
return
else if (child) {
setsid();
closefds();
fork();
if (child) {
childwork();
} else {
exit(0);
}
}
setsid
调用将守护进程放在自己的会话中,并将其与父进程的tty断开关联。如果不执行setsid
调用,那么就不会得到新的会话,守护进程可能会受到它仍然属于的进程组的干扰--也就是说,它可能受到发送到整个进程组的HUP
的干扰。
第二个fork()
调用导致流程不再是会话的领导者。这意味着,如果进程打开未使用的终端设备(意外或故意的),它将无法获得控制终端,因为它不是会话的领导者。如果仍然是会话领导者,那么您必须确保所有开放终端设备的开放调用都必须与O_NOCTTY
一起调用才是安全的。
https://stackoverflow.com/questions/20785486
复制相似问题