Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/assembly/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 最近启动的Google Compute Engine VM的非确定性连接成功_Python_Google Compute Engine_Paramiko - Fatal编程技术网

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