我正在尝试使用 Paramiko 通过 SSH 连接到 Brocade 交换机并执行远程命令。代码如下:
def ssh_connector(ip, userName, passWord, command):
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(ip, username=userName, password=passWord, port=22)
stdin, stdout, stderr = ssh.exec_command(command)
print stdout.readlines()
ssh_connector(ip, userName, passWord, 'show running-config')
在尝试运行代码时,我遇到了一个奇怪的错误,如下所示。
协议错误,不是以 scp 开头!
不知道错误原因,也不知道SSH连接是否成功。你能帮我解决这个问题吗?
SSHClient.exec_command
不起作用,首先要测试的是尝试(在one线上):
ssh user@host command
这将使用与
SSHClient.exec_command
相同的 SSH API(“exec”通道)。如果您使用的是 Windows,则可以使用 plink
(来自 PuTTY 软件包)而不是 ssh
。如果ssh
/plink
也失败,则表明您的设备不支持SSH“exec”通道。
在您的情况下,Brocade SSH 服务器上的“exec”通道似乎仅支持
scp
命令。
正如您声称能够“SSH”到交换机,似乎“shell”通道完全正常工作。
虽然通常不建议使用“shell”通道进行命令自动化,但对于您的服务器,您将没有其他选择。使用
SSHClient.invoke_shell
并使用 Channel.send
将命令写入通道(= 到 shell)。
channel = ssh.invoke_shell()
channel.send('ls\n')
channel.send('exit\n')
另请参阅Paramiko 上的 exec_command 和使用 invoke_shell() 发送有什么区别?
C#/SSH.NET 上的类似问题:SSH.NET 未在设备上执行命令。
强制性警告:请勿使用
AutoAddPolicy
– 这样做您将失去针对 MITM 攻击的保护。正确的解决方案请参阅Paramiko“未知服务器”。