versucht, den ECS-Treiber von libcloud für ein Projekt zu testen.Libcloud ECS Zugriff
i schrieb einen einfachen Test:
with open("conf.json") as f:
data = json.loads(f.read())
driver = get_driver(getattr(Provider,'ECS'))
with open('.cloud_credentials/'+data['provider']+'/access_id', 'r') as myfile:
ACCESS_KEY_ID = myfile.read().replace('\n', '')
print ACCESS_KEY_ID
with open('.cloud_credentials/'+data['provider']+'/secret_key', 'r') as myfile:
SECRET_KEY = myfile.read().replace('\n', '')
print SECRET_KEY
timer.start()
conn = driver(access_id = ACCESS_KEY_ID,
secret = SECRET_KEY,
region = 'us-east-1')
timer.stop()
cluster = conn.create_cluster('pippo','us-east-1')
Allerdings läuft es zu diesem Fehler:
Traceback (most recent call last):
File "launch.py", line 32, in <module>
cluster = conn.create_cluster('pippo',data['region'])
File "/home/sergio/anaconda2/lib/python2.7/site-packages/libcloud/container/drivers/ecs.py", line 151, in create_cluster
headers=self._get_headers('CreateCluster')
File "/home/sergio/anaconda2/lib/python2.7/site-packages/libcloud/common/base.py", line 604, in request
headers=headers, stream=stream)
File "/home/sergio/anaconda2/lib/python2.7/site-packages/libcloud/http.py", line 212, in request
verify=self.verification
File "/home/sergio/anaconda2/lib/python2.7/site-packages/requests/sessions.py", line 468, in request
resp = self.send(prep, **send_kwargs)
File "/home/sergio/anaconda2/lib/python2.7/site-packages/requests/sessions.py", line 576, in send
r = adapter.send(request, **kwargs)
File "/home/sergio/anaconda2/lib/python2.7/site-packages/requests/adapters.py", line 437, in send
raise ConnectionError(e, request=request)
requests.exceptions.ConnectionError: HTTPSConnectionPool(host='ecs.%s.amazonaws.com', port=443): Max retries exceeded with url:/(Caused by NewConnectionError('<requests.packages.urllib3.connection.VerifiedHTTPSConnection object at 0x7f5f16dca950>: Failed to establish a new connection: [Errno -2] Name or service not known',))
Ich denke, dass das Problem mit der Host-Zeichenfolge liegt, dass% s enthielt. dass String sieht aus wie eine Attrappe eines in der Datei initialisiert in der Bibliothek Graben:
/libcloud/container/drivers/ecs.py
Ich nehme an, dass es eine Funktion sollte irgendwo in diesen Dateien die Basis-String zu überschreiben, das wahrscheinlich nicht bekommen aus einigen Gründen, aber da er ein Neuling mit der libcloud-Bibliothek ist, macht es etwas schwierig, den Schuldigen zu finden.
Seltsamerweise, die Header Inspektion, die gesendet werden, sieht aus wie sie die richtige enthalten dort ansprechen (?):
headers: {'Host': u'ecs.us-east-1.amazonaws.com', 'User-Agent': 'libcloud/2.2.1 (Amazon Elastic Container Service) ', 'Content-Type': 'application/x-amz-json-1.1', 'Accept-Encoding': 'gzip,deflate', 'x-amz-target': 'AmazonEC2ContainerServiceV20141113.CreateCluster'}
Wer mit mehr Erfahrung mich in die richtige Richtung zeigen könnte? Es wäre sehr geschätzt.
ich weiß nicht ... könnte sein. Vielleicht weiß jemand etwas, was wir nicht wissen. – darkpirate