Package org.jclouds.compute.domain
Interface TemplateBuilder
- All Known Implementing Classes:
ArbitraryCpuRamTemplateBuilderImpl
,AWSEC2TemplateBuilderImpl
,EC2TemplateBuilderImpl
,GoogleComputeEngineArbitraryCpuRamTemplateBuilderImpl
,TemplateBuilderImpl
public interface TemplateBuilder
Creates a customized template based on requirements.
-
Method Summary
Modifier and TypeMethodDescriptionany()
prime this builder with parameters known to work on the current compute provider.biggest()
configure this template to the largest hardware, based on cores, ram, then diskbuild()
Generate an immutable template from the current builder.fastest()
configure this template to the fastest hardware, based on cpuForces an image lookup against the provider to reload the image cache.Configure and return this template, updating it with the populated values of the givenspec
.from
(TemplateBuilderSpec spec) Configure and return this template, updating it with the populated values of the givenspec
.fromHardware
(Hardware hardware) Configure this template to require the minimum hardware of the parameter.Configure this template to fuzzy-match on the image parameterfromTemplate
(Template image) Configure this template to match the resources of the template parameter.hardwareId
(String hardwareId) Configure this template to require a specific hardwareId.hypervisorMatches
(String hypervisorRegex) Configure this template to have an hypervisor that matches the regular expressionimageChooser
(com.google.common.base.Function<Iterable<? extends Image>, Image> imageChooser) Configure this template with a specific preference function which operates on images which match the other criteria.imageDescriptionMatches
(String imageDescriptionRegex) Configure this template to have an image description that matches the regular expressionConfigure this template to require a specific imageId.imageMatches
(com.google.common.base.Predicate<Image> condition) Configure this template to have an image that matches the supplied condition ex.imageNameMatches
(String imageNameRegex) Configure this template to have an image name that matches the regular expressionimageVersionMatches
(String imageVersionRegex) Configure this template to have an image version that matches the regular expressionlocationId
(String locationId) Configure this template to start in a specific locationminCores
(double minCores) Configure this template to require the minimum cores belowminDisk
(double gigabytes) Configure this template with required minimum disk space in gigabytesminRam
(int megabytes) Configure this template to require the minimum ram in megabytes belowoptions
(TemplateOptions options) Sets options on the template (i.e.os64Bit
(boolean is64bit) Configure this template to require a 64 bit operating system.osArchMatches
(String architecture) Configure this template to require a specific architecture.osDescriptionMatches
(String osDescriptionRegex) Configure this template to have an operating system description that matches the regular expressionConfigure this template to use a specific operating system image.osNameMatches
(String osNameRegex) Configure this template to have an operating system name that matches the regular expressionosVersionMatches
(String osVersionRegex) Configure this template to have an os version that matches the regular expressionsmallest()
configure this template to the smallest hardware, based on cores, ram, then disk
-
Method Details
-
any
TemplateBuilder any()prime this builder with parameters known to work on the current compute provider. -
fromHardware
Configure this template to require the minimum hardware of the parameter. -
fromImage
Configure this template to fuzzy-match on the image parameter -
fromTemplate
Configure this template to match the resources of the template parameter. -
from
Configure and return this template, updating it with the populated values of the givenspec
.- Since:
- 1.5
-
from
Configure and return this template, updating it with the populated values of the givenspec
. This is especially useful for command-line configuration of aTemplateBuilder
.- Parameters:
spec
- a String in the format specified byTemplateBuilderSpec
- Since:
- 1.5
-
smallest
TemplateBuilder smallest()configure this template to the smallest hardware, based on cores, ram, then disk -
fastest
TemplateBuilder fastest()configure this template to the fastest hardware, based on cpu -
biggest
TemplateBuilder biggest()configure this template to the largest hardware, based on cores, ram, then disk -
hypervisorMatches
Configure this template to have an hypervisor that matches the regular expression -
osFamily
Configure this template to use a specific operating system image. -
locationId
Configure this template to start in a specific location -
imageId
Configure this template to require a specific imageId. Note that image Ids are often scoped tolocation
-
hardwareId
Configure this template to require a specific hardwareId. -
osNameMatches
Configure this template to have an operating system name that matches the regular expression -
osDescriptionMatches
Configure this template to have an operating system description that matches the regular expression -
osVersionMatches
Configure this template to have an os version that matches the regular expression -
osArchMatches
Configure this template to require a specific architecture. ex. virtualizationType or -
os64Bit
Configure this template to require a 64 bit operating system. -
imageNameMatches
Configure this template to have an image name that matches the regular expression -
imageVersionMatches
Configure this template to have an image version that matches the regular expression -
imageDescriptionMatches
Configure this template to have an image description that matches the regular expression -
imageMatches
Configure this template to have an image that matches the supplied condition ex.builder.imageMatches(ImagePredicates.userMetadataContains("author", "sue"));
-
imageChooser
TemplateBuilder imageChooser(com.google.common.base.Function<Iterable<? extends Image>, Image> imageChooser) Configure this template with a specific preference function which operates on images which match the other criteria.If no function is supplied, jclouds will select one according to an internal strategy. This strategy may change from version to version.
-
minCores
Configure this template to require the minimum cores below -
minRam
Configure this template to require the minimum ram in megabytes below -
minDisk
Configure this template with required minimum disk space in gigabytes -
build
Template build()Generate an immutable template from the current builder. -
options
Sets options on the template (i.e. items which adorn a created node rather than restricting selection of the node). Note that this method typically replaces any options previously specified in the builder. Normal usage is to build up all options and pass them to the builder with a single call to this method. -
forceCacheReload
Forces an image lookup against the provider to reload the image cache.Use with caution. In some providers getting the list of images is an expensive operation, and the use of the image cache is recommended. If there is a need to minimize the amount of time the images are cached, consider configuring the cache expiration time by setting the
Constants.PROPERTY_SESSION_INTERVAL
property.- Since:
- 2.0
-