I am doing hands on in Paramiko lib. In the below code I created a shell and sent command ls. With sleep its working fine. But when I don’t use sleep it’s unable to capture output even if its just ls which happens to give output instantly on terminal. Also the order of output is very random (like how two thread’s output doesn’t follow any order.
import paramiko import time ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect('127.0.0.1', port=22, username='uname', password='pass', timeout=3) shell = ssh.invoke_shell() shell.send(b"lsn") # time.sleep(1) output = shell.recv(10000).decode("utf-8") print(output)
The output is like this:
ls Last login: Fri Dec 27 20:37:10 2024 from 127.0.0.1 or Last login: Fri Dec 27 20:37:11 2024 from 127.0.0.1 or Last login: Fri Dec 27 20:47:34 2024 from 127.0.0.1 ls or ls
I understand that it might be due to me not running time.sleep()
, but that should only affect the output. At the very least, it should show this every time –
Last login: Fri Dec 27 20:47:34 2024 from 127.0.0.1 ls
submitted by /u/CriticalDiscussion37
[link] [comments]
r/learnpython I am doing hands on in Paramiko lib. In the below code I created a shell and sent command ls. With sleep its working fine. But when I don’t use sleep it’s unable to capture output even if its just ls which happens to give output instantly on terminal. Also the order of output is very random (like how two thread’s output doesn’t follow any order. import paramiko import time ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect(‘127.0.0.1′, port=22, username=’uname’, password=’pass’, timeout=3) shell = ssh.invoke_shell() shell.send(b”lsn”) # time.sleep(1) output = shell.recv(10000).decode(“utf-8”) print(output) The output is like this: ls Last login: Fri Dec 27 20:37:10 2024 from 127.0.0.1 or Last login: Fri Dec 27 20:37:11 2024 from 127.0.0.1 or Last login: Fri Dec 27 20:47:34 2024 from 127.0.0.1 ls or ls I understand that it might be due to me not running time.sleep(), but that should only affect the output. At the very least, it should show this every time – Last login: Fri Dec 27 20:47:34 2024 from 127.0.0.1 ls submitted by /u/CriticalDiscussion37 [link] [comments]
I am doing hands on in Paramiko lib. In the below code I created a shell and sent command ls. With sleep its working fine. But when I don’t use sleep it’s unable to capture output even if its just ls which happens to give output instantly on terminal. Also the order of output is very random (like how two thread’s output doesn’t follow any order.
import paramiko import time ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect('127.0.0.1', port=22, username='uname', password='pass', timeout=3) shell = ssh.invoke_shell() shell.send(b"lsn") # time.sleep(1) output = shell.recv(10000).decode("utf-8") print(output)
The output is like this:
ls Last login: Fri Dec 27 20:37:10 2024 from 127.0.0.1 or Last login: Fri Dec 27 20:37:11 2024 from 127.0.0.1 or Last login: Fri Dec 27 20:47:34 2024 from 127.0.0.1 ls or ls
I understand that it might be due to me not running time.sleep()
, but that should only affect the output. At the very least, it should show this every time –
Last login: Fri Dec 27 20:47:34 2024 from 127.0.0.1 ls
submitted by /u/CriticalDiscussion37
[link] [comments]