如何从 Linux 中的另一个进程触发一个进程?

Posted

技术标签:

【中文标题】如何从 Linux 中的另一个进程触发一个进程?【英文标题】:How to trigger a process from another process in Linux? 【发布时间】:2019-02-08 08:45:35 【问题描述】:

我正在 Linux 上开发一个 C 应用程序。 为了清楚起见,我将我的问题翻译成两个简单的程序:

Prog1:创建一个文件并运行一个无限循环来读取它 Prog2:将单词“Hello”写入文件 10 次

每当将单词写入文件时,Prog1 中的无限循环都会检测到它并简单地读取它。 (最后两个代码都提到了)。

问题是:Prog1 实际上会尝试读取单词,然后休眠 1 秒钟,然后再尝试再次读取。我希望 Prog1 在写入文件后立即读取“Hello”一词(实时),如果可能的话,我想摆脱 Prog1 中的无限 while 循环。

这个问题有专业的解决方案吗?像一个特殊的高优先级中断来从 Prog2 触发 Prog1?

谢谢。

/* Prog1 */
#define FIFO_FILE "MYFIFO"
int main (void)

    int fd;
    int read_bytes;
    char buf[6];

    mknod(FIFO_FILE, S_IFIFO|0640,0);

    while(1)
    
        fd = open(FIFO_FILE, O_RDONLY);

        read_bytes = read(fd, buf, sizeof(buf));
        if(read_bytes == 0)
            break;

        buf[read_bytes] = '\0';

        printf("Received string is : %s \n", buf);

        sleep(1);
    

    close(fd);

    return 0;


/* Prog2 */
#define FIFO_FILE "MYFIFO"
int main (void)

    int fd;
    int stringlen;
    int count = 0;
    char buf[6]='H','e','l','l','o';

    fd = open(FIFO_FILE, O_CREAT|O_WRONLY);

    while(count <= 10)
       
        stringlen = strlen(buf);
        buf[stringlen] = '\0';

        write(fd, buf, strlen(buf));
        printf("Sent String \n");

        count++;

        sleep(1);

    

    close(fd);

    return 0;

【问题讨论】:

我认为pipes 或命名管道更适合此目的,甚至是套接字。您可以将它们与select 或poll 函数结合使用。 你可以发送一个信号来唤醒另一个进程。 man7.org/linux/man-pages/man7/signal.7.html 【参考方案1】:

您尝试做的就是命令tail -f 所做的事情。你可以去its source code看专业的解决方案。

另一方面,你不应该使用睡眠,而应该使用来自套接字库的poll

【讨论】:

旁注:GNU tail 正在使用 inotify 而不是 poll(如果可用) @hek2mgl 如果inotify 被禁用,我认为它会改用poll。正如我在这里看到的ibm.com/developerworks/linux/library/l-ubuntu-inotify,这只有在read 被传递一个文件系统描述符时才有效——没有任何类型的文件描述符接受这个。 感谢您的回答。我会花时间更详细地调查它。但是,该命令似乎只处理文件。如果 Prog2 将消息“Hello”写入共享内存而不是文件会怎样?单词写入内存后如何触发 Prog1? @Kalkhouri 正确。在你学习了 poll 的教程之后,你可以阅读 tail 的专业实现,然后你可以阅读 poll 是如何在内核中实现的,并实现你自己的 poll 版本来了解 tail 的细节。

以上是关于如何从 Linux 中的另一个进程触发一个进程?的主要内容,如果未能解决你的问题,请参考以下文章

我可以打开一个套接字并将其传递给 Linux 中的另一个进程吗

Linux学习-进程管理

在Win32(c ++)中的另一个进程中写入文本框

如何查找和杀掉Linux中的僵尸进程?

如何使用信号调用同一进程中的另一个线程在轮询函数上休眠的进程而不杀死它?

一个jvm中的java进程是不是有可能杀死/停止另一个jvm中的另一个java进程?