paramiko 无已有会话异常
我在使用Python的交互式命令行和本地运行的openssh时,遇到了一个问题,出现了“No existing session”的错误。我的代码如下:
import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('localhost',username=name,password=pw)
结果是:
No handlers could be found for logger "paramiko.transport"
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/local/lib/python2.6/dist-packages/paramiko-1.7.7.1-py2.6.egg/paramiko/client.py", line 332, in connect
self._auth(username, password, pkey, key_filenames, allow_agent, look_for_keys)
File "/usr/local/lib/python2.6/dist-packages/paramiko-1.7.7.1-py2.6.egg/paramiko/client.py", line 493, in _auth
raise saved_exception
paramiko.SSHException: No existing session
之前我能成功连接,但我一直在尝试调整设置,以便使用基于密钥的授权。结果失败了,从那以后我就无法再本地连接了。我尝试重启openssh,也成功连接到了其他服务器。在这里搜索后,我只找到了一些关于授权异常的讨论,但这似乎不是我遇到的问题。
6 个回答
4
我刚遇到了同样的错误 ERROR:SSHException('No existing session',)
,不过因为是在一个干净的docker容器里,所以没有ssh-agent。
经过几个小时的调试,我找到了一种不同的解决办法:这个错误可能是因为在密钥交换时超时了!在我的情况下,ssh服务器是通过GSM链接的路由器,这个速度非常慢。
你可以通过以下方式在paramiko中启用调试:
logging.getLogger("paramiko").setLevel(logging.DEBUG)
如果你在 Connected
和 Switch to new keys ...
之间看到这个异常,那就说明在密钥交换时超时了。在这种情况下,你需要把 timeout 设置得大一些!(文档上说 timeout 只是用于TCP连接,但实际上,它也适用于认证前的整个协商过程!)
14
我在我的ssh-add列表里有一个多余的公钥,并且它有一个密码。把它删掉后,我就能正常运行我的基于paramiko的脚本了。
要查看列表:
ssh-add -l
要删除所有:
ssh-add -D
要重新添加:
ssh-add /FULL/PATH/TO/id_rsa
56
因为你已经有了密码,所以不需要和代理人联系,也不用去找你电脑上存储的私钥。你可以试着添加一些额外的参数,比如 allow_agent
和 look_for_keys
:
ssh.connect('localhost',username=name,password=pw,allow_agent=False,look_for_keys=False)