вопрос о pexpect в питоне - PullRequest
       39

вопрос о pexpect в питоне

1 голос
/ 07 декабря 2010

Я попробовал и pexpect, и subprocess.Popen из python для вызова внешнего долгосрочного фонового процесса (этот процесс использует сокет для связи с внешними приложениями) со следующими подробностями.

  1. подпроцесс.Popen (launchcmd, stdin = subprocess.PIPE, stdout = subprocess.PIPE, stderr = subprocess.PIPE). Это прекрасно работает.Мне не нужно больше ничего делать.Однако, поскольку мне нужно немедленно получить вывод, я выбираю pexpect, чтобы избежать проблемы с буфером файла канала.

  2. obj = pexpect.spawn (launchcmd, timeout = None) после запуска внешнего процессаЯ использую отдельный поток, чтобы выполнить readline, чтобы прочитать вывод запущенного процесса obj, и все в порядке.

  3. obj = pexpect.spawn (launchcmd, timeout =Нет) после запуска внешнего процесса я больше ничего не делал, т.е. просто оставил его там.Хотя с помощью команды "ps -e" я могу найти запущенный процесс, но запущенный процесс кажется заблокированным и не может связываться через сокеты с другими приложениями.

ОК.Чтобы быть более конкретным, я добавил пример кода, чтобы сформулировать свой вопрос.

import subprocess
import pexpect
import os

t=1
while(True):
    if(t==1):
        background_process="./XXX.out"
        launchcmd = [background_process]
        #---option 3--------
        p=pexpect.spawn(launchcmd, timeout=None) # process launced, problem with socket.
        #---option 1--------
        p=subprocess.Popen(launchcmd, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) # process launced, everything fine
        t=0 

Может кто-нибудь сказать мне, что не так с третьим вариантом?И если это связано с тем, что я не использовал отдельный поток для управления выводом, почему 1-й вариант работает с subprocess.popen?Я подозреваю, что что-то не так с pexpect для запуска процесса с использованием сокета, но я не уверен, особенно учитывая, что вариант 2 работает хорошо.

1 Ответ

1 голос
/ 07 июля 2011

Я думаю, что вы делаете это слишком сложным.

Да, это хорошая идея использовать pty вместо pipe для связи с фоновым процессом, потому что большинство приложений распознают tty /устройства pty и переключитесь на использование небуферизованного вывода (или, по крайней мере, линейного буферизации).

Но почему pexpect?Просто используйте pty модуль Python.Сначала вызовите openpty, чтобы получить некоторые файловые дескрипторы, а затем используйте Popen, чтобы вызвать процесс.Пример кода можно найти в следующем вопросе (ответ с зеленой галочкой) Python Запустить подпроцесс демона и прочитать стандартный вывод

...