Class DockerTemplateOptions
- All Implemented Interfaces:
- Cloneable
createNodes operation on the docker provider.
 Usage
The recommended way to instantiate a DockerTemplateOptions object is to statically importDockerTemplateOptions.Builder.* and invoke one of
 the static creation methods, followed by an instance mutator if needed.
 
 import static org.jclouds.docker.compute.options.DockerTemplateOptions.Builder.*;
 ComputeService api = // get connection
 templateBuilder.options(inboundPorts(22, 80, 8080, 443));
 Set<? extends NodeMetadata> set = api.createNodesInGroup(tag, 2, templateBuilder.build());
 
 Advanced Usage
 In addition to basic configuration through its methods, this class also
 provides possibility to work directly with Docker API configuration object (
 Config.Builder). When the
 configBuilder(org.jclouds.docker.domain.Config.Builder) is used to
 configure not-null configBuilder, then this configuration object
 takes precedence over the other configuration in this class (i.e. the other
 config entries are not used)
 
 Note: The image property in the provided Config.Builder is rewritten by a placeholder value.
 The real value is configured by ComputeServiceAdapter.
 
 import static org.jclouds.docker.compute.options.DockerTemplateOptions.Builder.*;
 ComputeService api = // get connection
 DockerTemplateOptions options = DockerTemplateOptions.Builder
       .configBuilder(
                Config.builder().env(ImmutableList.<String> of("SSH_PORT=8822"))
                      .hostConfig(HostConfig.builder().networkMode("host").build()));
 templateBuilder.options(options);
 Set<? extends NodeMetadata> set = api.createNodesInGroup("sample-group", 1, templateBuilder.build());
 - 
Nested Class SummaryNested ClassesNested classes/interfaces inherited from class org.jclouds.compute.options.TemplateOptionsTemplateOptions.ImmutableTemplateOptionsNested classes/interfaces inherited from class org.jclouds.compute.options.RunScriptOptionsRunScriptOptions.ImmutableRunScriptOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Config.Builderprotected Integerprotected Stringprotected Integerprotected Stringprotected booleanprotected booleanFields inherited from class org.jclouds.compute.options.TemplateOptionsblockUntilRunning, inboundPorts, networks, nodeNames, NONE, privateKey, publicKey, script, securityGroups, tags, userMetadataFields inherited from class org.jclouds.compute.options.RunScriptOptionsauthenticateSudo, blockOnComplete, loginPassword, loginPrivateKey, loginUser, port, runAsRoot, seconds, taskName, wrapInInitScript
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionauthorizePublicKey(String publicKey) authorize an rsa ssh key.blockOnPort(int port, int seconds) When the node is started, wait until the following port is activeblockUntilRunning(boolean blockUntilRunning) Noteclone()configBuilder(Config.Builder configBuilder) This method sets Config.Builder configuration object, which can be used as a replacement for all the other settings from this class.voidentrypoint(Iterable<String> entrypoint) entrypoint(String... entrypoint) booleanextraHosts(Map<String, String> extraHosts) Set extra hosts file entries for a container.getDns()getEnv()booleanbooleaninthashCode()inboundPorts(int... ports) Opens the set of ports to public access.installPrivateKey(String privateKey) replaces the rsa ssh key used at login.networkMode(String networkMode) Sets the networking mode for the container.Assigns the created nodes to these networksspecifies names to be used for the created nodes.openStdin(boolean openStdin) KeepSTDINopen when running interactive workloads in the container.overrideAuthenticateSudo(boolean authenticateSudo) overrideLoginCredentials(LoginCredentials overridingCredentials) overrideLoginPassword(String password) overrideLoginPrivateKey(String privateKey) overrideLoginUser(String loginUser) portBindings(Map<Integer, Integer> portBindings) Set port bindings between the Docker host and a container.privileged(boolean privileged) By default, Docker containers are unprivileged and cannot execute privileged operations or access certain host devices.runAsRoot(boolean runAsRoot) This script will be executed as the root user upon system startup.toString()userMetadata(String key, String value) userMetadata(Map<String, String> userMetadata) volumesFrom(Iterable<String> volumesFrom) Set list of containers to mount volumes from onto this container.Methods inherited from class org.jclouds.compute.options.TemplateOptionsas, blockOnComplete, getGroups, getInboundPorts, getNetworks, getNodeNames, getPrivateKey, getPublicKey, getRunScript, getTags, getUserMetadata, networks, runScript, securityGroups, securityGroups, shouldBlockUntilRunning, string, tags, wrapInInitScriptMethods inherited from class org.jclouds.compute.options.RunScriptOptionscopyTo, getLoginPassword, getLoginPrivateKey, getLoginUser, getPort, getSeconds, getTaskName, hasLoginPassword, hasLoginPasswordOption, hasLoginPrivateKey, hasLoginPrivateKeyOption, overrideLoginPassword, overrideLoginPrivateKey, shouldAuthenticateSudo, shouldBlockOnComplete, shouldRunAsRoot, shouldWrapInInitScript
- 
Field Details- 
dns
- 
hostname
- 
memory
- 
volumes
- 
env
- 
portBindings
- 
networkMode
- 
extraHosts
- 
volumesFrom
- 
privilegedprotected boolean privileged
- 
openStdinprotected boolean openStdin
- 
configBuilder
 
- 
- 
Constructor Details- 
DockerTemplateOptionspublic DockerTemplateOptions()
 
- 
- 
Method Details- 
clone- Overrides:
- clonein class- TemplateOptions
 
- 
copyTo- Overrides:
- copyToin class- TemplateOptions
 
- 
equals- Overrides:
- equalsin class- TemplateOptions
 
- 
hashCodepublic int hashCode()- Overrides:
- hashCodein class- TemplateOptions
 
- 
toString- Overrides:
- toStringin class- RunScriptOptions
 
- 
volumes
- 
dns
- 
dns
- 
hostname
- 
memory
- 
entrypoint
- 
entrypoint
- 
commands
- 
commands
- 
env
- 
env
- 
portBindingsSet port bindings between the Docker host and a container.The Mapkeys are host ports number, and the value for an entry is the container port number. This is the same order as the arguments for the--publishcommand-line option todocker runwhich ishostPort:containerPort.- Parameters:
- portBindings- the map of host to container port bindings
 
- 
networkModeSets the networking mode for the container.Supported values are: bridge,none,host,networkname,networkidorcontainer:[name|id]- Parameters:
- networkMode-
- Returns:
- this instance
 
- 
extraHostsSet extra hosts file entries for a container.The Mapkeys are host names, and the value is an IP address that can be accessed by the container. This is the same order as the arguments for the--add-hostcommand-line option todocker run.- Parameters:
- extraHosts- the map of host names to IP addresses
 
- 
volumesFromSet list of containers to mount volumes from onto this container.- Parameters:
- volumesFrom- the list of container names
 
- 
privilegedBy default, Docker containers are unprivileged and cannot execute privileged operations or access certain host devices.- Parameters:
- privileged- Whether the container should run in privileged mode or not
- Returns:
- this instance
 
- 
openStdinKeepSTDINopen when running interactive workloads in the container.- Parameters:
- openStdin- Whether the container should keep STDIN open
- Returns:
- this instance
 
- 
configBuilderThis method sets Config.Builder configuration object, which can be used as a replacement for all the other settings from this class. Some values in the provided Config.Builder instance (the image name for instance) can be ignored or their value can be changed.- Parameters:
- configBuilder- Config.Builder instance. This instance can be changed in this method!
 
- 
getVolumes
- 
getDns
- 
getVolumesFrom
- 
getHostname
- 
getMemory
- 
getEntrypoint
- 
getCommands
- 
getEnv
- 
getPortBindings
- 
getNetworkMode
- 
getExtraHosts
- 
getPrivilegedpublic boolean getPrivileged()
- 
getOpenStdinpublic boolean getOpenStdin()
- 
getConfigBuilder
- 
blockOnPortWhen the node is started, wait until the following port is active- Overrides:
- blockOnPortin class- TemplateOptions
 
- 
inboundPortsOpens the set of ports to public access.- Overrides:
- inboundPortsin class- TemplateOptions
 
- 
authorizePublicKeyauthorize an rsa ssh key.- Overrides:
- authorizePublicKeyin class- TemplateOptions
 
- 
installPrivateKeyreplaces the rsa ssh key used at login.- Overrides:
- installPrivateKeyin class- TemplateOptions
 
- 
blockUntilRunningNoteAs of version 1.1.0, this option is incompatible withTemplateOptions.runScript(Statement)andRunScriptOptions.blockOnComplete(boolean), as all current implementations utilize ssh in order to execute scripts.- Overrides:
- blockUntilRunningin class- TemplateOptions
- Parameters:
- blockUntilRunning- (default true) whether to block until the nodes in this template are instate- invalid reference- Status#RUNNING
 
- 
dontAuthorizePublicKey- Overrides:
- dontAuthorizePublicKeyin class- TemplateOptions
 
- 
nameTask- Overrides:
- nameTaskin class- TemplateOptions
- Returns:
- What to call the task relating to this script; default
         jclouds-script-timestampwhere timestamp is millis since epoch
 
- 
runAsRoot- Overrides:
- runAsRootin class- TemplateOptions
 
- 
runScriptThis script will be executed as the root user upon system startup. This script gets a prologue, so no #!/bin/bash required, path set up, etc- Overrides:
- runScriptin class- TemplateOptions
 
- 
overrideLoginCredentials- Overrides:
- overrideLoginCredentialsin class- TemplateOptions
 
- 
overrideLoginPassword- Overrides:
- overrideLoginPasswordin class- TemplateOptions
 
- 
overrideLoginPrivateKey- Overrides:
- overrideLoginPrivateKeyin class- TemplateOptions
 
- 
overrideLoginUser- Overrides:
- overrideLoginUserin class- TemplateOptions
 
- 
overrideAuthenticateSudo- Overrides:
- overrideAuthenticateSudoin class- TemplateOptions
 
- 
userMetadata- Overrides:
- userMetadatain class- TemplateOptions
- Parameters:
- userMetadata- user-defined metadata to assign to this server
 
- 
userMetadata- Overrides:
- userMetadatain class- TemplateOptions
- Parameters:
- key- key to place into the metadata map
- value- value to associate with that key
 
- 
nodeNamesspecifies names to be used for the created nodes. Note that this does not guarantee uniqueness - if there are already existing nodes with a name specified here, there will still be a new node created with the same name. Also, if more nodes are to be created than there are names, subsequent names will use the default naming strategy for that cloud.- Overrides:
- nodeNamesin class- TemplateOptions
 
- 
networksAssigns the created nodes to these networks- Overrides:
- networksin class- TemplateOptions
 
 
-