Popen.stdout.readline () работает в Python 3.2, но возвращает пустую строку в Python 3.6 - PullRequest
5 голосов
/ 25 апреля 2019

Я использую Popen для запуска процесса telnet через ssh, отправляю команды через telnet и проверяю выходной процесс для мониторинга состояния telnet.Странная вещь, с которой я столкнулся, заключается в том, что код отлично работает с Python 3.2.3, но когда я запускаю его в Python 3.6.5 без изменений кода, он не может получить вывод.

Я пробовал

  • очистка stdout

  • ожидание до 10 секунд после stdout.write

  • проверено stderr

def nonblockingread(sout):
   fd = output.fileno()
   fl = fcntl.fcntl(fd, fcntl.F_GETFL)
   try:
       return sout.read()
   except:
       return ""

process = Popen(shlex.split("ssh anon@server \"telnet 0 2323\""), stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
print(nonblockingread(process.stdout)) # works for both versions
process.stdin.write(b"start service 4\n")
print(nonblockingread(process.stdout)) # works in 3.2 but not 3.6 (prints empty line)
print(process.stdout.readline()) # also prints empty line in 3.6

1 Ответ

2 голосов
/ 25 апреля 2019

Буферизация была включена по умолчанию в 3.2.4 и 3.3.1 , так как она была случайно отключена в Python 3. Вам необходимо flush ваш write, чтобыprocess.stdin чтобы другая сторона увидела что-нибудь.

...