linux监控程序-程序自动重启方法

1)exec函数把当前进程替换为一个新的进程,新进程由path或file参数指定。可以使用exec函数将程序的执行从一个程序切换到另一个程序;

2)fork函数是创建一个新的进程,在进程表中创建一个新的表项,而创建者(即父进程)按原来的流程继续执行,子进程执行自己的控制流程;

3)wait 当fork启动一个子进程时,子进程就有了它自己的生命周期并将独立运行,我们可以在父进程中调用wait函数让父进程等待子进程的结束;

相信介绍到这里,读者已经能够想到解决方法了:1)首先使用fork系统调用,创建子进程,2)在子进程中使用exec函数,执行需要自动重启的程序,3) 在父进程中执行wait等待子进程的结束,然后重新创建一个新的子进程。

#include <stdio.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <stdlib.h>

int
main(int argc, char **argv){
   int ret, i, status;
   char *child_argv[100] = {0};
    pid_t pid;
    if(argc <</span> 2) {
       fprintf(stderr, "Usage:%s n", argv[0]);
        return -1;
    }
    for(i = 1; i <argc; ++i) {
       child_argv[i-1] = (char *)malloc(strlen(argv[i])+1);
        strncpy(child_argv[i-1], argv[i], strlen(argv[i]));
        child_argv[i-1][strlen(argv[i])] = '0';
    }
    while(1){
        pid =fork();
        if(pid == -1) {
           fprintf(stderr, "fork() error.errno:%d error:%sn",errno, strerror(errno));
           break;
        }
      if(pid == 0) {
            ret =execv(child_argv[0], (char **)child_argv);
            //ret = execl(child_argv[0], "portmap", NULL, 0);
            if(ret <</span> 0) {
                fprintf(stderr, "execv ret:%d errno:%d error:%sn", ret, errno, strerror(errno));
                continue;
            }
            exit(0);
        }

        if(pid > 0) {
            pid =wait(&status);
            fprintf(stdout, "wait return");
        }
    }
    return 0;
}

你可能感兴趣的:(linux)