Python 命名管道

在一项项目中,为了使多个无父子关系的独立进程能够交互,采用了Python的命名管道进行进程通信。为了确保消息完整性和并发安全性,通过文件锁来实现读写操作的原子性。
摘要由CSDN通过智能技术生成

最近一个做一个项目,需要多个进程交互。同时,这几个进程需要各自独立启动,并无父子关系,评估后决定使用命名管道方式进行进程通信。为保证消息完整性以及并发安全,使用文件锁保证读写的原子性。代码如下:

import multiprocessing
import os
import traceback
import time
import json
import sys
import fcntl

class Pipe:
    def __init__(self, pipe_name):
        file_path = "/tmp/"
        try:
            self.fifo_path = "{}{}.pipe".format(file_path, pipe_name)
            os.mkfifo(self.fifo_path)
        except Exception:
            print(traceback.format_exc())
        self.block_file = "/tmp/block_{}.file".format(pipe_name)
        if not os.path.exists(self.block_file):
            f = open(self.block_file, "w")
            f.close()
        self.fp_block = open(self.block_file, "w")

    def __lock(self, flag=fcntl.LOCK_EX | fcntl.LOCK_NB):
        fcntl.flock(self.fp_block.fileno(), flag)

    def __unlock(self):
        fcntl.flock(self.fp_block.filen
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值