paramiko 无已有会话异常

32 投票
6 回答
46292 浏览
提问于 2025-04-16 22:18

我在使用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)

如果你在 ConnectedSwitch 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_agentlook_for_keys

ssh.connect('localhost',username=name,password=pw,allow_agent=False,look_for_keys=False)

撰写回答