Class AzureComputeServiceAdapter
- java.lang.Object
-
- org.jclouds.azurecompute.arm.compute.AzureComputeServiceAdapter
-
- All Implemented Interfaces:
ComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
@Singleton public class AzureComputeServiceAdapter extends Object implements ComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
Defines the connection between theAzureComputeApi
implementation and the jcloudsComputeService
.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.jclouds.compute.ComputeServiceAdapter
ComputeServiceAdapter.NodeAndInitialCredentials<N>
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description ComputeServiceAdapter.NodeAndInitialCredentials<VirtualMachine>
createNodeWithGroupEncodedIntoName(String group, String name, Template template)
ComputeService.createNodesInGroup(String, int, Template)
generates the parameters passed into this method such that each node in the set has a unique name.void
destroyNode(String id)
VMImage
getImage(String id)
get a specific image by idVirtualMachine
getNode(String id)
Iterable<VMHardware>
listHardwareProfiles()
Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node.Iterable<VMImage>
listImages()
Images are the available configured operating systems that someone can run a node with.Iterable<Location>
listLocations()
Iterable<VirtualMachine>
listNodes()
Iterable<VirtualMachine>
listNodesByIds(Iterable<String> ids)
void
rebootNode(String id)
void
resumeNode(String id)
void
suspendNode(String id)
-
-
-
Field Detail
-
GROUP_KEY
public static final String GROUP_KEY
- See Also:
- Constant Field Values
-
AUTOGENERATED_IP_KEY
public static final String AUTOGENERATED_IP_KEY
- See Also:
- Constant Field Values
-
logger
@Named("jclouds.compute") protected Logger logger
-
-
Method Detail
-
createNodeWithGroupEncodedIntoName
public ComputeServiceAdapter.NodeAndInitialCredentials<VirtualMachine> createNodeWithGroupEncodedIntoName(String group, String name, Template template)
Description copied from interface:ComputeServiceAdapter
ComputeService.createNodesInGroup(String, int, Template)
generates the parameters passed into this method such that each node in the set has a unique name.note
It is intentional to return the library native node object, as generic typeN
. If you are not using library-native objects (such as libvirtDomain
) useJCloudsNativeComputeServiceAdapter
instead.note
Your responsibility is to create a node with the underlying library and return after storing its credentials in the supplied map corresponding tocredentialStore
- Specified by:
createNodeWithGroupEncodedIntoName
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
- Parameters:
group
- used to aggregate nodes with identical configurationname
- unique supplied name for the node, which has the group encoded into it.template
- includesimageId
,locationId
, andhardwareId
used to resume the instance.- Returns:
- library-native representation of a node. TODO: return typed exception on createNodeFailure
- See Also:
ComputeService.createNodesInGroup(String, int, Template)
-
listHardwareProfiles
public Iterable<VMHardware> listHardwareProfiles()
Description copied from interface:ComputeServiceAdapter
Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node. To implement this method, return the library native hardware profiles available to the user. These will be used to launch nodes as a part of the template.- Specified by:
listHardwareProfiles
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
- Returns:
- a non-null iterable of available hardware profiles.
- See Also:
ComputeService.listHardwareProfiles()
-
listImages
public Iterable<VMImage> listImages()
Description copied from interface:ComputeServiceAdapter
Images are the available configured operating systems that someone can run a node with. To implement this method, return the library native images available to the user. These will be used to launch nodes as a part of the template.- Specified by:
listImages
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
- Returns:
- a non-null iterable of available images.
- See Also:
ComputeService.listImages()
-
getImage
public VMImage getImage(String id)
Description copied from interface:ComputeServiceAdapter
get a specific image by id- Specified by:
getImage
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
- Parameters:
id
-Image#getId
, which is not necessarilyImage#getProviderId
- Returns:
- image or null if not exists.
-
listLocations
public Iterable<Location> listLocations()
- Specified by:
listLocations
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
getNode
public VirtualMachine getNode(String id)
- Specified by:
getNode
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
destroyNode
public void destroyNode(String id)
- Specified by:
destroyNode
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
rebootNode
public void rebootNode(String id)
- Specified by:
rebootNode
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
resumeNode
public void resumeNode(String id)
- Specified by:
resumeNode
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
suspendNode
public void suspendNode(String id)
- Specified by:
suspendNode
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
listNodes
public Iterable<VirtualMachine> listNodes()
- Specified by:
listNodes
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
listNodesByIds
public Iterable<VirtualMachine> listNodesByIds(Iterable<String> ids)
- Specified by:
listNodesByIds
in interfaceComputeServiceAdapter<VirtualMachine,VMHardware,VMImage,Location>
-
-