Linux上的python中的程序间通信

前端之家收集整理的这篇文章主要介绍了Linux上的python中的程序间通信前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

有很多关于如何找到这些东西的例子:

1)在同一程序中的不同进程之间进行通信.

2)通过网络在客户端/服务器之间进行通信

但是,这个问题在我看过的任何地方都没有很好的例子:

>从python程序A向程序B发送字符串的规范方法是什么,它阻止并处理该字符串,然后在循环中等待另一个字符串?

我觉得我已经多次接近答案,但从未设法创造一个有效的例子.

其他隐含要求:

>实际上有两个不同的程序:该示例需要实际上有两个不同的程序(即两个文件progA.py,progB.py可以在同一台机器上的两个屏幕中从命令行单独运行),不使用任何类型的分叉或multiprocess来创建客户端和服务器.
>请建议一种方法,允许发送长度合理的可变长度分隔字符串,而不是必须得到正确的数据大小的确切字节数. (后者在实现中更容易出错).
>理想情况下,不使用localhost互联网连接即可

例如;读者使用时:

pipein = open(pipe_name,'r')
while program.KeepRunning:
    action = pipein.readline()[:-1]
    program.processLine(line)
    time.sleep(1)

而作者使用:

command = "enable"
pipeout = os.open(pipe_name,os.O_WRONLY)
os.write(pipeout,command)
os.write(pipeout,"\n")

正如在http://www.python-course.eu/pipes.php所建议的那样
读者陷入无限循环,读出空字符串.

有趣的是,在program.processLine函数添加if(action ==’enable’):longFunction()会导致longFunction中的部分代码被执行,然后才能永久地读出空行.

另一方面,利用更现代的低级别子流程模块的所有示例仅涉及多线程应用程序,而不涉及多个应用程序.其他实现涉及套接字和网络.

虽然我尝试使用套接字,但这会导致通用的“出错”类型错误,导致许多可能的原因错误111:“连接拒绝”显示“某些时间”.作为在接收某些命令时执行的python代码的一部分,实际修改网络配置(例如,它使用各种参数调用ip,tc和iptables等命令)利用到localhost的网络连接是可能应该避免的,导致困难调试和一般讨厌的问题.除了第二个程序在同一台机器上运行时不必要的部分,因此任何程序间通信都不需要使用网络接口.

最佳答案
这是预期的行为.请查看this answer以了解类似问题和FIFO行为概述.与您的问题相关的部分是:

When there are no more writers (…) readers are notified about that through read() returning the EOF.

file.readline()docs说”(空字符串)表示已达到EOF:

if f.readline() returns an empty string,the end of the file has been reached,while a blank line is represented by '\n',a string containing only a single newline.

而已.在每次尝试读取的无限循环中,您将获得一个空字符串,表示没有连接的编写器.

没有什么可以阻止您使用命名管道来解决您的任务.最简单的方法就是在没有作家的情况下睡一段时间.这是工作示例:

# server.py

import os
import time

pipe_name = 'pipe_test'

if not os.path.exists(pipe_name):
    os.mkfifo(pipe_name)

with open(pipe_name,'r') as pipe:
    print("Listening for actions...")
    while True:
        action = pipe.readline()[:-1]
        if action == '':
            print("No clients. Sleeping...")
            time.sleep(1)
        else:
            print("Action received:",repr(action))
# client.py

import os

pipe_name = 'pipe_test'

if not os.path.exists(pipe_name):
    os.mkfifo(pipe_name)

print("Waiting for server to start...")
with open(pipe_name,'w') as pipe:
    action = input("Enter action to send: ")
    pipe.write(action + '\n')

笔记:

>使用os.open()是没有意义的,它是低级函数.您可以使用open()与命名管道进行交互.
>打开命名管道以读取blocks,直到连接第一个作者.因此,在第一个客户端连接到管道之前,您不会在输出中看到“侦听操作…”.作家也是如此,没有读者就开始了.
>您要求“阻止并处理此字符串,然后在循环中等待另一个字符串”.除非您在单独的线程中处理字符串,否则在处理当前字符串之前不会尝试读取下一个字符串.

猜你在找的Linux相关文章