jclouds-labs azurecompute 获取 ComputeService 对象
jclouds-labs azurecompute getting a ComputeService object
使用 Jclouds 和 jclouds-labs azurecompute
我有以下代码片段,它按预期工作
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 的 AWS 和 GCE
ContextBuilder contextBuilder = newContextBuilder(cloudProvider);
ComputeService cs = contextBuilder
.credentials(identity, credential)
.buildView(ComputeServiceContext.class)
.getComputeService();
如何让 AzureComputeApi 成为 return 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
Azure 计算仍在开发中,ComputeService 抽象仍在进行中,因此您还不能使用它;您必须直接使用 AzureComputeApi。如果您想了解最新信息,可以跟踪 JCLOUDS-664。
使用 Jclouds 和 jclouds-labs azurecompute 我有以下代码片段,它按预期工作
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 的 AWS 和 GCE
ContextBuilder contextBuilder = newContextBuilder(cloudProvider);
ComputeService cs = contextBuilder
.credentials(identity, credential)
.buildView(ComputeServiceContext.class)
.getComputeService();
如何让 AzureComputeApi 成为 return 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
Azure 计算仍在开发中,ComputeService 抽象仍在进行中,因此您还不能使用它;您必须直接使用 AzureComputeApi。如果您想了解最新信息,可以跟踪 JCLOUDS-664。