有两个信号可以挂起进程的执行。一种是“优雅”,一种是“有力”。
“优美”的是SIGTSTP,其目的是“很好地”询问该过程(如果感觉合适),请中止执行,直到收到为止SIGCONT。在的情况下SIGTSTP,该进程可以忽略SIGTSTP并继续执行,因此需要与旨在处理SIGTSTP的程序进行合作。
“强制”是SIGSTOP,其目的是挂起与该进程关联的所有用户空间线程。忽略流程SIGSTOP就像忽略它一样是不可能的SIGKILL(后者会强行杀死流程)。
要发送任意的信号,包括任何这里提到的那些,你可以使用程序,如kill,killall或pkill; 或使用系统调用kill(2)。有关与平台/体系结构/版本有关的详细信息和上述内容的勘误,请参见操作系统的手册。请注意,所有这些命令和系统调用中的“ kill”一词都是错误的误称。这些命令并非专门用于终止进程。他们可以通过发送某些信号来做到这一点;但是信号也可以用于终止进程以外的功能。例如,SIGSTOP仅暂停该过程,而这只是可以通过这种方式发送的多个信号之一。
要添加的自动恢复过程后的一段时间已经过去一个条件,你将需要使用某种形式的剩余,并设定一个计时器,以唤醒监控过程,然后又调用监控过程的kill(2)一次发送SIGCONT信号到停止的进程,以请求内核恢复执行。请注意,Linux有几种计时机制,其准确性和精确度各不相同。此外,如果您的系统非常繁忙,则可能要等到其计时器到期后才能唤醒监视过程,因此唤醒时间可能会延迟。
如果你依赖于挂起的进程的中止和恢复的非常准确的精度,您可能需要通过实时权限运行监控程序(见本手册页上sched_setscheduler(2)有关建立用户进程的实时信息)。您还可以将高分辨率计时器(Linux内核的一项功能(仅当您的硬件提供对它们的支持时才可用))与实时调度结合使用,以获得非常精确的亚毫秒级精度,然后唤醒并发送信号以非常快速地恢复受监视的过程。
您没有指出愿意使用哪些技术来实现此目的。尽管您将无法以这种方式获得非常精细的时序,但至少需要至少bash脚本。这是一个bash“脚本”(未经测试,请小心),它只是查询概念的证明。如果需要精确的计时,则可能必须使用C / C ++或另一种本地语言编写程序,并使用实时调度和hrtimers。
#!/bin/bash
#This is the process you want to suspend.
screen -mdS child bash -c "cat /dev/urandom | base64"
#This is the process ID of the child process
THEPID=$(screen -list | grep child | cut -f1 -d'.' | sed 's/\W//g')
#Send SIGSTOP to the child process.
kill -SIGSTOP ${THEPID}
#Now it is suspended. This process will sleep for 10 seconds asynchronously, then resume the process.
screen -mdS monitor bash -c "sleep 10; kill -SIGCONT ${THEPID}"
请注意,脚本将结束并且控制脚本将终止,但是由于screen控制了监视进程,它将继续在后台运行10秒钟(基于传递给的参数sleep),然后唤醒并继续执行子进程。但这将在控制脚本结束后很长时间。如果要同步等待时间过去,则只需省略对的第二个调用,screen并对睡眠进行硬编码并杀死到控制脚本中即可。
您可以通过运行以下命令来测试该进程是否实际上已挂起
screen -rS child
启动此脚本后。您不会在控制台上看到任何内容。然后,计时器到期(10秒)后,它将以base64数据(0-9和AF中的随机字符)淹没您的屏幕。按Ctrl + C退出。