


How to gracefully handle 'pipe closed' error in Python multi-process Pipe communication?
Python multi-process Pipe communication: elegant solution to "pipe closed" error
You may encounter a headache "pipe closed" error when using Pipe
method in Python's multiprocessing
module for interprocess communication. This article will analyze this problem in depth and provide a more robust solution.
Problems usually occur in parent-child process communication scenarios. For example, after a child process performs a time-consuming task, it sends data to the parent process through a pipeline and waits for the parent process's signal to end itself. If the parent process ends early and the child process tries to receive data from a closed pipeline, a "pipeline closed" error is raised.
While adding time.sleep()
and explicitly closing child processes in parent processes can solve the problem, this is not an ideal solution because it relies on active waiting and control of the parent process.
A more elegant solution is to catch the EOFError
exception in the child process . This exception is raised when the child process tries to receive data from the pipeline when the parent process ends early. By catching this exception, the child process can exit gracefully, avoiding program crashes.
The following shows the improved service.py
and single.py
code:
Improved service.py
:
import os from multiprocessing import Process, Pipe def start_child_process(child_conn): # Simulate time-consuming tasks# run_server_for_long_time() child_conn.send({"port": 123, "ret": 1, "pid": os.getpid()}) try: signal = child_conn.recv() # Wait for parent process signal if signal: child_conn.close() except EOFError as e: print(f"EOFError: {e}") # Elegant handling of exceptions# You can add the necessary cleanup work here class Server: def __init__(self): self.child_conn = None self.child = None self.parent_conn, self.child_conn = Pipe() def run(self): self.child = Process(target=start_child_process, name="my_child_process", args=(self.child_conn,)) self.child.start() data = self.parent_conn.recv() result = { "endpoints": { "http": f"http://127.0.0.1:{data['port']}/cmd", "ws": f"ws://127.0.0.1:{data['port']}/api", } } return result def stop(self): self.parent_conn.send(True) self.child.join() self.child = None if __name__ == "__main__": server = Server() r = server.run() print("r:", r)
Improved single.py
:
from service import Server def main(): server = Server() result = server.run() print("r:", result) # server.stop() # Optional: explicitly stop the child process if __name__ == "__main__": main()
Catching EOFError
by adding try...except
block in the child process, the child process ends gracefully even if the parent process exits unexpectedly, avoiding the "pipeline closed" error. This approach improves the robustness of the program without relying on explicit shutdown operations of the parent process.
The above is the detailed content of How to gracefully handle 'pipe closed' error in Python multi-process Pipe communication?. For more information, please follow other related articles on the PHP Chinese website!

The article discusses Python's new "match" statement introduced in version 3.10, which serves as an equivalent to switch statements in other languages. It enhances code readability and offers performance benefits over traditional if-elif-el

Exception Groups in Python 3.11 allow handling multiple exceptions simultaneously, improving error management in concurrent scenarios and complex operations.

Function annotations in Python add metadata to functions for type checking, documentation, and IDE support. They enhance code readability, maintenance, and are crucial in API development, data science, and library creation.

The article discusses unit tests in Python, their benefits, and how to write them effectively. It highlights tools like unittest and pytest for testing.

Article discusses access specifiers in Python, which use naming conventions to indicate visibility of class members, rather than strict enforcement.

Article discusses Python's \_\_init\_\_() method and self's role in initializing object attributes. Other class methods and inheritance's impact on \_\_init\_\_() are also covered.

The article discusses the differences between @classmethod, @staticmethod, and instance methods in Python, detailing their properties, use cases, and benefits. It explains how to choose the right method type based on the required functionality and da

InPython,youappendelementstoalistusingtheappend()method.1)Useappend()forsingleelements:my_list.append(4).2)Useextend()or =formultipleelements:my_list.extend(another_list)ormy_list =[4,5,6].3)Useinsert()forspecificpositions:my_list.insert(1,5).Beaware


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Zend Studio 13.0.1
Powerful PHP integrated development environment
