C中的后台进程(守护进程)未执行vp()-ing

C中的后台进程(守护进程)未执行vp()-ing,c,unix,process,background,exec,C,Unix,Process,Background,Exec,所以,我试图运行一个后台进程并从中执行VP。 当我输入cp/path/file/var/tmp时,进程并没有复制文件 以下是我的代码供参考: void cmd_bg(char command[]) { pid_t process_id = 0; pid_t sid = 0; char* argv[512]; getArgv(command,argv); // Create child process

所以,我试图运行一个后台进程并从中执行VP。 当我输入cp/path/file/var/tmp时,进程并没有复制文件

以下是我的代码供参考:

void cmd_bg(char command[])
{
        pid_t process_id = 0;
        pid_t sid = 0;
        char* argv[512];
        getArgv(command,argv);
        // Create child process
        process_id = fork();
        // Indication of fork() failure
        if (process_id < 0)
        {
                printf("fork failed!\n");
                // Return failure in exit status
                exit(1);
        }
        // PARENT PROCESS. Need to kill it.
        if (process_id > 0)
        {
                printf("process_id of child process %d \n", process_id);
                // return success in exit status
                exit(0);
        }
        //unmask the file mode
        umask(0);
        //set new session
        sid = setsid();
        if(sid < 0)
        {
                // Return failure
                exit(1);
        }
        // Change the current working directory to root.
        chdir("/");
        // Close stdin. stdout and stderr
        close(STDIN_FILENO);
        close(STDOUT_FILENO);
        close(STDERR_FILENO);


        execvp(argv[0],argv);

        }
}
void getArgv(char command[], char* argv[512])
{
        char *token;
        int count = 0;
        int pid = 0;
        int ex = 0;
        char *absPath;
        char pwdtemp[512];
        strcpy(pwdtemp,pwd);

        token = strtok(command, " ");
        while(token!=NULL)
        {
                argv[count++] = token;
                printf("%s\n",argv[count-1]);
                token = strtok(NULL," ");
        }
        argv[count] = '\0';
}
接下来,我没有直接调用cmd_bg,而是创建了:

void temp1(char command[])
{
    int pid = fork();
    if(pid==0)
        cmd_bg(command);

    else
        waitpid(-1, NULL, 0);
}

它现在似乎起作用了!谢谢你们的投入,伙计们

您是否尝试过不关闭标准输入、标准输出、标准错误

我会检查execvp是否返回(它只在出现错误时返回),并查看它产生了什么errno。这可能有助于您追踪问题。

您有没有可能调用您的程序
cp
?如果是这种情况,则
execvp()
将反复调用该程序,而不是
/bin/cp
。获取完整的代码也会很有帮助。

我也有同样的想法,但如何跟踪进程何时不与shell交互?(因为它是分离的)。对不起,如果这是一个简单的问题,请原谅,我是C新手,我是JAVA人!如果您的系统有syslog(linux应该),您可以尝试包含syslog.h并调用syslog。您的日志记录将(可能)附加到/var/log/messages的末尾。该目录中没有名为messages的文件。我尝试了syslog(LOG_NOTICE,“XXX”);并包含syslog.h您正在运行哪个发行版?如果是debian(或ubuntu),请尝试编辑/etc/rsyslog.conf。应该有一个类似于
*.=notice/var/log/messages
*.*/var/log/messages
的条目。对于其他发行版,它可能是/etc/syslog.conf。请将代码的相关部分内联发布,而不是发布在外部网站上。仍然不完整。main()在哪里?“pwd”的定义在哪里。。。和
argv[count]='\0'应该是
argv[count]=NULL有趣!但是不,我的程序不叫cp!
void temp1(char command[])
{
    int pid = fork();
    if(pid==0)
        cmd_bg(command);

    else
        waitpid(-1, NULL, 0);
}