channel.recv_exit_status в paramiko всегда возвращает код возврата первой команды, выполненной над invoke_shell

Я получаю некоторые расхождения в коде возврата ниже. Может быть, я не использую должным образом. Каждый раз, когда я печатаю код возврата, он печатает так же, как первый возвращенный. Нужно ли сбросить код возврата. Я имею в виду в следующем примере, я получаю код возврата как 2 для обеих команд. Теперь, когда я обмениваю обе команды, я имею в виду заменить ls -al;exit\n с ls -al file_not_exist;exit\n и наоборот, он печатает код возврата 0. Каждый раз, когда он печатает тот же код возврата, что и первый, который вернулся.

ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
ssh.connect('localhost', username='sam', password='mypassword')

channel = ssh.invoke_shell()
channel.send('ls -al file_not_exist;exit\n') #Sending to list a file which doesn't exist
time.sleep(3)
print "My 1st command exit status is: ",channel.exit_status_ready()
print "My 1st command return code is: ", channel.recv_exit_status()

channel.send('ls -al;exit\n')
time.sleep(3)
print "My 2nd command exit status is: ",channel.exit_status_ready()
print "My 2nd command return code is: ",channel.recv_exit_status()

Мне нужно напечатать код возврата каждой команды. Не могли бы вы помочь мне, как решить эту проблему?

1 ответ

Состояние выхода, отправляемое через ssh, соответствует состоянию удаленной команды, выполняемой процессом ssh. Вы получаете только один статус выхода, а в случае invoke_shell(), то есть статус выхода самой оболочки. Статус завершения команд, запускаемых в этой оболочке, известен только в этой среде.

Вам нужно либо получить и проанализировать состояние в оболочке или скрипте (ярлык bash является переменной $?), или выполните ваши команды независимо с exec_command(),

Смотрите также: Могу ли я получить код завершения команды, выполняемой в подоболочке через ssh?

Другие вопросы по тегам