Python 最近启动的Google Compute Engine VM的非确定性连接成功
我正在使用Python 最近启动的Google Compute Engine VM的非确定性连接成功,python,google-compute-engine,paramiko,Python,Google Compute Engine,Paramiko,我正在使用googleapiclientpythonapi启动一个vm,然后paramiko通过ssh连接到它 我使用googleapiclient.discovery获取GCEapi compute = googleapiclient.discovery.build('compute', 'v1') 我使用api调用启动我的vm 然后,我执行一个请求来查找vm详细信息,并依次查找短暂的外部ip地址 req = compute.instances().get(project, zone, i
googleapiclient
pythonapi启动一个vm,然后paramiko
通过ssh连接到它
我使用googleapiclient.discovery
获取GCE
api
compute = googleapiclient.discovery.build('compute', 'v1')
我使用api调用启动我的vm
然后,我执行一个请求来查找vm详细信息,并依次查找短暂的外部ip地址
req = compute.instances().get(project, zone, instance)
info = req.execute()
ip_address = info['networkInterfaces'][0]['accessConfigs'][0]['natIP']
最后,我使用paramiko
连接到此ip地址
ssh_client = paramiko.SSHClient()
ssh_client.connect(ip_address)
非确定性地,connect
调用失败:
这似乎与时间有关,因为在ssh\u client.connect
调用之前加入time.sleep(5)
,可以防止此错误
我假设这允许sshd
有足够的时间开始接受连接,但我不确定
在我的代码中加入睡眠是非常困难的,因此我更愿意找到一种方法,确定地等待ssh守护进程运行并可供我连接到它(如果这确实是导致NoValidConnections
异常的原因)
- 是否有方法指示GCE api仅在VM运行时从
返回,并且start
可供我连接sshd
- 是否有办法使用GCE api请求此信息
或者,我看到
paramiko
在connect
调用中有一个timeout
选项-我是否应该将我的5秒睡眠更改为5秒超时?GCE无法知道来宾是否可以使用SSH。(例如,假设客户使用非标准方法允许远程连接,因此即使检查sshd
也不起作用。即使您可以依赖sshd
,检查其运行的方式取决于其版本、主机操作系统、配置等)GCE只知道有关VM的硬件级别信息,例如它是否重新启动
为了解决您的问题,我会像您描述的那样在paramiko中尝试超时机制,或者可能会在循环中重试连接尝试并超时,因为paramiko可能不会在内部实现完全状态重置重试(只是猜测,我不确定)
另外,我认为5秒可能有点低——对于平均响应时间来说可能没问题,但异常值会更慢,这可能会导致连接尝试变得不稳定。为了完全安全,可能会将时间缩短到30秒或一分钟。谢谢你的建议!
ssh_client = paramiko.SSHClient()
ssh_client.connect(ip_address)
.../lib/python3.6/site-packages/paramiko/client.py", line 362, in connect
raise NoValidConnectionsError(errors)
paramiko.ssh_exception.NoValidConnections Error:
[Errno None] Unable to connect to port 22 on xxx.xxx.xxx.xxx