SSHClient to prosta klasa opakowująca obejmująca bardziej niższą funkcjonalność w Paramiko. Dokumentacja API zawiera listę recv_exit_status()
metod w Channel
klasie.
Bardzo prosty skrypt demonstracyjny:
import paramiko
import getpass
pw = getpass.getpass()
client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.WarningPolicy())
client.connect('127.0.0.1', password=pw)
while True:
cmd = raw_input("Command to run: ")
if cmd == "":
break
chan = client.get_transport().open_session()
print "running '%s'" % cmd
chan.exec_command(cmd)
print "exit status: %s" % chan.recv_exit_status()
client.close()
Przykład jego wykonania:
$ python sshtest.py
Password:
Command to run: true
running 'true'
exit status: 0
Command to run: false
running 'false'
exit status: 1
Command to run:
$
recv_exit_status
, nie możesz go używać w ten sposób, ponieważ kod może się zablokować. Musisz zużywać dane wyjściowe polecenia, czekając na zakończenie polecenia. Zobacz Paramiko ssh die / hang z dużym wyjściem .O wiele prostszy przykład, który nie obejmuje bezpośredniego wywoływania klasy kanału „niższego poziomu” (tj. - NIE przy użyciu
client.get_transport().open_session()
polecenia):źródło
recv_exit_status
, nie możesz go używać w ten sposób, ponieważ kod może się zablokować. Musisz zużywać dane wyjściowe polecenia, czekając na zakończenie polecenia. Zobacz Paramiko ssh die / hang z dużym wyjściem .Dzięki dla JanC, dodałem trochę modyfikacji do przykładu i przetestowałem w Pythonie3, jest to dla mnie naprawdę przydatne.
źródło
W moim przypadku problemem było buforowanie wyjścia. Ze względu na buforowanie dane wyjściowe z aplikacji nie wychodzą w sposób nieblokujący. Odpowiedź na temat sposobu drukowania danych wyjściowych bez buforowania można znaleźć tutaj: Wyłącz buforowanie wyjściowe . Krótko mówiąc, po prostu uruchom Pythona z opcją -u w następujący sposób:
> python -u script.py
źródło