Я использую Popen для запуска процесса telnet через ssh, отправки команд через telnet и проверки процесса на вывод, чтобы отслеживать состояние telnet. Странная вещь, с которой я столкнулся, заключается в том, что код отлично работает с Python 3.2.3, но когда я запускаю его в Python 3.6.5 без изменений кода, он не может получить результат.
я пытался
сброс стандартного вывода
ожидание до 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
Это была опечатка
Кажется, не хватает какого-то кода — например, вы никогда не устанавливаете ничего неблокирующего. Ваша «служба 4» действительно запущена?






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