Python 하위 프로세스 Readlines()가 중단됨
문제 설명:
스트리밍을 시도할 때 subprocess 모듈, readlines() 호출 블록을 사용하여 Python에서 Ruby 파일을 한 줄씩 실행합니다. 무기한으로 인해 추가 실행이 방지됩니다.
원인:
이 문제는 Linux가 아닌 운영 체제에서 pty 모듈을 사용하여 의사 터미널을 시뮬레이션할 때 발생할 수 있습니다. pty는 Linux 전용 라이브러리이며 다른 시스템에서의 동작은 보장되지 않습니다.
해결책:
1. Pexpect 사용:
Pexpect는 대화형 애플리케이션 자동화를 위해 설계된 크로스 플랫폼 라이브러리입니다. 의사 터미널을 통해 데이터를 보내고 받기 위한 고급 인터페이스를 제공합니다.
import pexpect pexpect.run("ruby ruby_sleep.rb", logfile=sys.stdout)
2. Stdbuf 사용:
Stdbuf를 사용하면 비대화형 모드에서 라인 버퍼링을 활성화하여 모든 라인에서 출력을 플러시할 수 있습니다.
proc = Popen(['stdbuf', '-oL', 'ruby', 'ruby_sleep.rb'], bufsize=1, stdout=PIPE, stderr=STDOUT, close_fds=True) for line in iter(proc.stdout.readline, b''): print(line) proc.stdout.close() proc.wait()
3. 표준 라이브러리의 Pty 사용(Linux용):
import errno import os import pty from subprocess import Popen, STDOUT master_fd, slave_fd = pty.openpty() # provide tty to enable line-buffering on Ruby's side proc = Popen(['ruby', 'ruby_sleep.rb'], stdin=slave_fd, stdout=slave_fd, stderr=STDOUT, close_fds=True) os.close(slave_fd) try: while 1: try: data = os.read(master_fd, 512) except OSError as e: if e.errno != errno.EIO: raise break # EIO means EOF on some systems else: if not data: # EOF break print('got ' + repr(data)) finally: os.close(master_fd) if proc.poll() is None: proc.kill() proc.wait() print("This is reached!")
위 내용은 Ruby 출력을 스트리밍할 때 Python의 `subprocess.readlines()`가 중단되는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!