在Linux系统中,僵尸进程是指已经结束运行但尚未被其父进程回收资源的进程。为了避免僵尸进程的产生,可以采取以下措施:
wait()或waitpid()函数:
wait()或waitpid()函数来等待子进程结束,并回收其资源。#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
int main() {
pid_t pid = fork();
if (pid == 0) {
// 子进程
_exit(0);
} else if (pid > 0) {
// 父进程
int status;
waitpid(pid, &status, 0); // 等待子进程结束
} else {
// 错误处理
perror("fork");
}
return 0;
}
signal()或sigaction()函数来设置信号处理函数,当子进程退出时发送SIGCHLD信号给父进程。wait()或waitpid()来回收子进程资源。#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
void sigchld_handler(int signum) {
int status;
pid_t pid;
while ((pid = waitpid(-1, &status, WNOHANG)) > 0) {
printf("Child process %d exited with status %d\n", pid, status);
}
}
int main() {
struct sigaction sa;
sa.sa_handler = sigchld_handler;
sigemptyset(&sa.sa_mask);
sa.sa_flags = SA_RESTART;
if (sigaction(SIGCHLD, &sa, NULL) == -1) {
perror("sigaction");
exit(EXIT_FAILURE);
}
pid_t pid = fork();
if (pid == 0) {
// 子进程
_exit(0);
} else if (pid > 0) {
// 父进程
printf("Parent process waiting for child process to finish...\n");
sleep(10); // 模拟父进程其他工作
} else {
// 错误处理
perror("fork");
exit(EXIT_FAILURE);
}
return 0;
}
nohup和&nohup命令:
nohup命令可以让进程忽略挂起信号(SIGHUP),并且默认情况下会将输出重定向到nohup.out文件。nohup your_command &
setsid()setsid()函数创建一个新的会话,使进程成为会话领导者,这样子进程的退出不会影响到父进程。#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
int main() {
pid_t pid = fork();
if (pid == 0) {
// 子进程
setsid(); // 创建新的会话
_exit(0);
} else if (pid > 0) {
// 父进程
printf("Parent process waiting for child process to finish...\n");
wait(NULL); // 等待子进程结束
} else {
// 错误处理
perror("fork");
exit(EXIT_FAILURE);
}
return 0;
}
systemd服务systemd管理服务:
systemd服务运行,systemd会自动处理进程的生命周期,包括子进程的回收。# /etc/systemd/system/your_service.service
[Unit]
Description=Your Service
[Service]
ExecStart=/path/to/your_command
Restart=always
[Install]
WantedBy=multi-user.target
然后使用以下命令启动和管理服务:
sudo systemctl daemon-reload
sudo systemctl start your_service
sudo systemctl enable your_service
通过以上方法,可以有效地防止僵尸进程的产生,确保系统的稳定性和资源的正确回收。