2015-02-04 1 views
1

Используя Jclouds и jclouds-лаборатории azurecompute я следующий код надрез-он, который работает, как ожидалосьjclouds-лаборатории azurecompute получение объекта ComputeService

ContextBuilder contextBuilder = ContextBuilder.newBuilder(cloudProvider); 

AzureComputeApi api = contextBuilder 
    .credentials(keyStoreLocation, keyStorePassword) 
    .endpoint(uri + subscriptionId) 
    .buildApi(AzureComputeApi.class); 

List<Location> locations = api.getLocationApi().list(); 
for(Location l : locations) 
    System.out.println(l); 

AzureComputeApi подключается и печать ожидается выход

Location{name=West Europe, displayName=West Europe, availableServices=[Compute, Storage, PersistentVMRole, HighMemory]} 
Location{name=North Europe, displayName=North Europe, availableServices=[Compute, Storage, PersistentVMRole, HighMemory]} 
... 

Однако моя существующая база кода jclouds работает с типом ComputeService, например этот подход работает АМС в cloudProvider и GCE

ContextBuilder contextBuilder = newContextBuilder(cloudProvider); 

ComputeService cs = contextBuilder 
    .credentials(identity, credential) 
    .buildView(ComputeServiceContext.class) 
    .getComputeService(); 

Как я могу получить AzureComputeApi вернуть ComputeService (или какой-либо вещь, на этот счет), так что я не должен изменить существующий код базы?
это можно.

Если я пытаюсь этот код чик-он, используя cloudPprovider = azurecompute

ContextBuilder contextBuilder = ContextBuilder.newBuilder(cloudProvider); 
ComputeService cs = contextBuilder 
    .credentials(keyStoreLocation, keyStorePassword) 
    .endpoint(uri + subscriptionId) 
    .buildView(ComputeServiceContext.class) 
    .getComputeService(); 

Я получаю это исключение брошено

Exception in thread "main" java.lang.IllegalArgumentException: api {id=azurecompute, name=Microsoft Azure Service Management Service API, views=[], endpointName=Service Management Endpoint ending in your Subscription Id, identityName=Path to Management Certificate .p12 file, or PEM string, credentialName=Optional.of(Password to Management Certificate), documentation=http://msdn.microsoft.com/en-us/library/ee460799, api=interface org.jclouds.azurecompute.AzureComputeApi} not wrappable as org.jclouds.compute.ComputeServiceContext; context: org.jclouds.rest.ApiContext<org.jclouds.azurecompute.AzureComputeApi>, views: [] 
    at org.jclouds.ContextBuilder.buildView(ContextBuilder.java:604) 
    at org.jclouds.ContextBuilder.buildView(ContextBuilder.java:588) 
    at com.hazelcast.stabilizer.provisioner.ComputeServiceBuilder.main(ComputeServiceBuilder.java:79) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120) 

Я знаю, что все мои keyStoreLocation, keyStorePassword, Uri + SubscriptionId переменные в порядке как они работают Если я обрабатываю AzureComputeApi direct

ответ

1

Azure-вычисление все еще находится в разработке, а абстракция ComputeService все еще работает в pr ogress, так что вы еще не можете его использовать; вы должны использовать непосредственно AzureComputeApi. Вы можете отслеживать JCLOUDS-664, если вы хотите остаться в курсе последних новостей.

+0

Спасибо, за информацию. вы могли бы разместить некоторые ссылки на создание экземпляров с AzureComputeApi. Я тоже искал, но на самом деле не нашел много, спасибо снова – dmc

Смежные вопросы