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 < 2) {
- fprintf(stderr, "Usage:%s <exe_path> <args...>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 < 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;
- }
点击(此处)折叠或打开
- # 函数: CheckProcess
- # 功能: 检查一个进程是否存在
- # 参数: $1 --- 要检查的进程名称
- # 返回: 如果存在返回0, 否则返回1.
- #------------------------------------------------------------------------------
- CheckProcess()
- {
- # 检查输入的参数是否有效
- if [ "$1" = "" ];
- then
- return 1
- fi
- #$PROCESS_NUM获取指定进程名的数目,为1返回0,表示正常,不为1返回1,表示有错误,需要重新启动
- PROCESS_NUM=`ps -ef | grep "$1" | grep -v "grep" | wc -l`
- if [ $PROCESS_NUM -eq 1 ];
- then
- return 0
- else
- return 1
- fi
- }
- # 检查test实例是否已经存在
- while [ 1 ] ; do
- CheckProcess "test"
- CheckQQ_RET=$?
- if [ $CheckQQ_RET -eq 1 ];
- then
- # 杀死所有test进程,可换任意你需要执行的操作
- killall -9 test
- exec ./test &
- fi
- sleep 1
- done