Paramiko 问题 - 执行命令时通道关闭
Paramiko Issues - Channel Closed when Executing a Command
我一直在尝试 运行 在 Overture Box 上使用 paramiko 命令建立 SSH 连接。
我的脚本确实正确连接到盒子,没有发现任何问题,当脚本 运行s exec_command(cmd) 方法时出现问题:
Traceback (most recent call last):
File "test.py", line 39, in <module>
stdin, stdout, stderr = ssh.exec_command("version")
File "/opt/csw/lib/python2.7/site-packages/paramiko/client.py", line 345, in exec_command
chan.exec_command(command)
File "/opt/csw/lib/python2.7/site-packages/paramiko/channel.py", line 60, in _check
return func(self, *args, **kwds)
File "/opt/csw/lib/python2.7/site-packages/paramiko/channel.py", line 229, in exec_command
self._wait_for_event()
File "/opt/csw/lib/python2.7/site-packages/paramiko/channel.py", line 1086, in _wait_for_event
raise e
paramiko.ssh_exception.SSHException: Channel closed.
使用 Linux Box 作为目标主机的相同脚本会产生正确的结果
代码是借来的,刚搜到片段谷歌:
import sys
import time
import select
import paramiko
host = raw_input("Hostname?: ")
i = 1
password = raw_input("Password?: ")
#
# Try to connect to the host.
# Retry a few times if it fails.
#
while True:
print "Trying to connect to %s (%i/30)" % (host, i)
try:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(host, port=22, username="username", password=password)
print "Connected to %s" % host
break
except paramiko.AuthenticationException:
print "Authentication failed when connecting to %s" % host
sys.exit(1)
except:
print "Could not SSH to %s, waiting for it to start" % host
i += 1
time.sleep(2)
# If we could not connect within time limit
if i == 30:
print "Could not connect to %s. Giving up" % host
sys.exit(1)
# Send the command (non-blocking)
stdin, stdout, stderr = ssh.exec_command("version")
# Wait for the command to terminate
while not stdout.channel.exit_status_ready():
# Only print data if there is data to read in the channel
if stdout.channel.recv_ready():
rl, wl, xl = select.select([stdout.channel], [], [], 0.0)
if len(rl) > 0:
# Print data from stdout
print stdout.channel.recv(1024),
#
# Disconnect from the host
#
print "Command done, closing SSH connection"
ssh.close()
我发现了其他问题,据说问题可能与主机中的 SFTP 设置有关,但我能够做到:
sftp username@hostname
我用 Google 搜索了一段时间,但到目前为止找不到任何有用的信息。
在此先感谢您的帮助。
编辑:差点忘了,我知道问题就在:
stdin, stdout, stderr = ssh.exec_command("version")
我以交互方式 运行 整个脚本,当我 运行 该行时它中断了。
可能是 Overture 不支持 SSH exec_command 请求。
我需要使用 transport.open_session()
、session.get_pty()
和 session.invoke_shell()
来设置交互式 shell 会话,然后使用 session.send()
和 session.recv()
到 write/read 到 Cisco 交换机和其他网络设备的 shell 会话,当 exec_command()
不可用时。
这里有一个解决方法,
- 为您的连接获取传输。
- 打开会话。
然后 exec_command(command) and then
recv()`,不用睡觉了。
client.connect("host", port=22, username="user",password= "pass",look_for_keys=False, allow_agent=False)
transport=client.get_transport()
channel = t.open_session()
channel.exec_command(command)
out = channel.recv(-1)
print(out.decode())
我一直在尝试 运行 在 Overture Box 上使用 paramiko 命令建立 SSH 连接。
我的脚本确实正确连接到盒子,没有发现任何问题,当脚本 运行s exec_command(cmd) 方法时出现问题:
Traceback (most recent call last):
File "test.py", line 39, in <module>
stdin, stdout, stderr = ssh.exec_command("version")
File "/opt/csw/lib/python2.7/site-packages/paramiko/client.py", line 345, in exec_command
chan.exec_command(command)
File "/opt/csw/lib/python2.7/site-packages/paramiko/channel.py", line 60, in _check
return func(self, *args, **kwds)
File "/opt/csw/lib/python2.7/site-packages/paramiko/channel.py", line 229, in exec_command
self._wait_for_event()
File "/opt/csw/lib/python2.7/site-packages/paramiko/channel.py", line 1086, in _wait_for_event
raise e
paramiko.ssh_exception.SSHException: Channel closed.
使用 Linux Box 作为目标主机的相同脚本会产生正确的结果
代码是借来的,刚搜到片段谷歌:
import sys
import time
import select
import paramiko
host = raw_input("Hostname?: ")
i = 1
password = raw_input("Password?: ")
#
# Try to connect to the host.
# Retry a few times if it fails.
#
while True:
print "Trying to connect to %s (%i/30)" % (host, i)
try:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(host, port=22, username="username", password=password)
print "Connected to %s" % host
break
except paramiko.AuthenticationException:
print "Authentication failed when connecting to %s" % host
sys.exit(1)
except:
print "Could not SSH to %s, waiting for it to start" % host
i += 1
time.sleep(2)
# If we could not connect within time limit
if i == 30:
print "Could not connect to %s. Giving up" % host
sys.exit(1)
# Send the command (non-blocking)
stdin, stdout, stderr = ssh.exec_command("version")
# Wait for the command to terminate
while not stdout.channel.exit_status_ready():
# Only print data if there is data to read in the channel
if stdout.channel.recv_ready():
rl, wl, xl = select.select([stdout.channel], [], [], 0.0)
if len(rl) > 0:
# Print data from stdout
print stdout.channel.recv(1024),
#
# Disconnect from the host
#
print "Command done, closing SSH connection"
ssh.close()
我发现了其他问题,据说问题可能与主机中的 SFTP 设置有关,但我能够做到:
sftp username@hostname
我用 Google 搜索了一段时间,但到目前为止找不到任何有用的信息。
在此先感谢您的帮助。
编辑:差点忘了,我知道问题就在:
stdin, stdout, stderr = ssh.exec_command("version")
我以交互方式 运行 整个脚本,当我 运行 该行时它中断了。
可能是 Overture 不支持 SSH exec_command 请求。
我需要使用 transport.open_session()
、session.get_pty()
和 session.invoke_shell()
来设置交互式 shell 会话,然后使用 session.send()
和 session.recv()
到 write/read 到 Cisco 交换机和其他网络设备的 shell 会话,当 exec_command()
不可用时。
这里有一个解决方法,
- 为您的连接获取传输。
- 打开会话。
然后
exec_command(command) and then
recv()`,不用睡觉了。client.connect("host", port=22, username="user",password= "pass",look_for_keys=False, allow_agent=False) transport=client.get_transport() channel = t.open_session() channel.exec_command(command) out = channel.recv(-1) print(out.decode())