RunCommandProps
Properties for defining a RunCommand
.
See https://www.alibabacloud.com/help/ros/developer-reference/aliyun-ecs-runcommand
Initializer
import com.aliyun.ros.cdk.ecs.RunCommandProps;
RunCommandProps.builder()
.commandContent(java.lang.String)
.commandContent(IResolvable)
.instanceIds(IResolvable)
.instanceIds(java.util.List<java.lang.String)
.instanceIds(IResolvable>)
.type(java.lang.String)
.type(IResolvable)
// .containerId(java.lang.String)
// .containerId(IResolvable)
// .containerName(java.lang.String)
// .containerName(IResolvable)
// .contentEncoding(java.lang.String)
// .contentEncoding(IResolvable)
// .description(java.lang.String)
// .description(IResolvable)
// .enableParameter(java.lang.Boolean)
// .enableParameter(IResolvable)
// .frequency(java.lang.String)
// .frequency(IResolvable)
// .keepCommand(java.lang.Boolean)
// .keepCommand(IResolvable)
// .name(java.lang.String)
// .name(IResolvable)
// .parameters(IResolvable)
// .parameters(java.util.Map<java.lang.String, java.lang.Object>)
// .repeatMode(java.lang.String)
// .repeatMode(IResolvable)
// .resourceGroupId(java.lang.String)
// .resourceGroupId(IResolvable)
// .runAgainOn(IResolvable)
// .runAgainOn(java.util.List<java.lang.String)
// .runAgainOn(IResolvable>)
// .sync(java.lang.Boolean)
// .sync(IResolvable)
// .tags(java.util.List<TagsProperty>)
// .timeout(java.lang.Number)
// .timeout(IResolvable)
// .username(java.lang.String)
// .username(IResolvable)
// .windowsPasswordName(java.lang.String)
// .windowsPasswordName(IResolvable)
// .workingDir(java.lang.String)
// .workingDir(IResolvable)
.build();
Properties
Name | Type | Description |
---|---|---|
commandContent |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property commandContent: The plaintext content or the Base64-encoded content of the script. |
instanceIds |
com.aliyun.ros.cdk.core.IResolvable OR java.util.List |
Property instanceIds: The instance id list. |
type |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property type: The language type of the O&M script. |
containerId |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property containerId: The ID of the container. |
containerName |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property containerName: The name of the container. |
contentEncoding |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property contentEncoding: The encoding mode of script content (CommandContent). |
description |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property description: The description of the script, which supports all character sets. |
enableParameter |
java.lang.Boolean OR com.aliyun.ros.cdk.core.IResolvable |
Property enableParameter: Specifies whether the script contains custom parameters. |
frequency |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property frequency: The execution period of recurring tasks. |
keepCommand |
java.lang.Boolean OR com.aliyun.ros.cdk.core.IResolvable |
Property keepCommand: Specifies whether to retain the script after it is run. |
name |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property name: The name of the script, which supports all character sets. |
parameters |
com.aliyun.ros.cdk.core.IResolvable OR java.util.Map |
Property parameters: The key-value pairs of custom parameters passed in when the script contains custom parameters. |
repeatMode |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property repeatMode: Specifies how to run the command. |
resourceGroupId |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property resourceGroupId: The ID of the resource group to which to assign the command executions. |
runAgainOn |
com.aliyun.ros.cdk.core.IResolvable OR java.util.List |
Property runAgainOn: The stage of executing the command again. |
sync |
java.lang.Boolean OR com.aliyun.ros.cdk.core.IResolvable |
Property sync: Whether to invoke synchronously. |
tags |
java.util.List<TagsProperty> |
Property tags: Tags to attach to run_command. |
timeout |
java.lang.Number OR com.aliyun.ros.cdk.core.IResolvable |
Property timeout: The timeout period for script execution. |
username |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property username: The username to use to run the command on instances. |
windowsPasswordName |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property windowsPasswordName: The name of the password to use to run the command on Windows instances. |
workingDir |
java.lang.String OR com.aliyun.ros.cdk.core.IResolvable |
Property workingDir: The running directory of the script in the ECS instance. |
commandContent
Required
public java.lang.Object getCommandContent();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property commandContent: The plaintext content or the Base64-encoded content of the script.
The Base64-encoded script content cannot exceed 16 KB. You can enable the custom parameter function by setting EnableParameter=true in the script content: Define custom parameters in the {{}} format. Within {{}}, the spaces and line breaks before and after the name of the parameter are ignored. The number of custom parameters cannot exceed 20. A custom parameter name can contain only letters, digits, underscores (_), and hyphens (-). It is case insensitive. Each custom parameter key cannot exceed 64 bytes.
instanceIds
Required
public java.lang.Object getInstanceIds();
- Type: com.aliyun.ros.cdk.core.IResolvable OR java.util.List
Property instanceIds: The instance id list.
Instances status must be running.
type
Required
public java.lang.Object getType();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property type: The language type of the O&M script.
Valid values: RunBatScript: batch scripts for Windows instances RunPowerShellScript: PowerShell scripts for Windows instances RunShellScript: shell scripts for Linux instances
containerId
Optional
public java.lang.Object getContainerId();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property containerId: The ID of the container.
Only 64-bit hexadecimal strings are supported. You can use container IDs that are prefixed with docker://, containerd://, or cri-o:// to specify container runtimes. Take note of the following items:
- If you specify this parameter, Cloud Assistant runs scripts in the specified container of the instance.
- If you specify this parameter, make sure that the version of Cloud Assistant Agent installed on Linux instances is 2.2.3.344 or later.- If you specify this parameter, Username that is specified in a request to call this operation and WorkingDir that is specified in a request to call the CreateCommand operation do not take effect. You can run the command only in the default working directory of the container by using the default user of the container.
- If you specify this parameter, only shell scripts can be run in Linux containers. You cannot add a command in the format similar to #!/usr/bin/python at the beginning of a script to specify a script interpreter.
containerName
Optional
public java.lang.Object getContainerName();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property containerName: The name of the container.
Take note of the following items:
- If you specify this parameter, Cloud Assistant runs scripts in the specified container of the instance.
- If you specify this parameter, make sure that the version of Cloud Assistant Agent installed on Linux instances is 2.2.3.344 or later.
- If you specify this parameter, Username that is specified in a request to call this operation and WorkingDir that is specified in a request to call the CreateCommand operation do not take effect. You can run the command only in the default working directory of the container by using the default user of the container.
- If you specify this parameter, only shell scripts can be run in Linux containers. You cannot add a command in the format similar to #!/usr/bin/python at the beginning of a script to specify a script interpreter.
contentEncoding
Optional
public java.lang.Object getContentEncoding();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property contentEncoding: The encoding mode of script content (CommandContent).
Valid values (case insensitive): PlainText: The script content is not encoded, and transmitted in plaintext. Base64: base64-encoded. Default value: PlainText. If the specified value of this parameter is invalid, PlainText is used by default.
description
Optional
public java.lang.Object getDescription();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property description: The description of the script, which supports all character sets.
It can be up to 512 characters in length.
enableParameter
Optional
public java.lang.Object getEnableParameter();
- Type: java.lang.Boolean OR com.aliyun.ros.cdk.core.IResolvable
Property enableParameter: Specifies whether the script contains custom parameters.
Default value: false
frequency
Optional
public java.lang.Object getFrequency();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property frequency: The execution period of recurring tasks.
If the Timed parameter is set to True, you must specify the Frequency parameter. The interval between two recurring tasks cannot be less than 10 seconds. The parameter value follows the cron expression. For more information, see Configure scheduled commands.
keepCommand
Optional
public java.lang.Object getKeepCommand();
- Type: java.lang.Boolean OR com.aliyun.ros.cdk.core.IResolvable
Property keepCommand: Specifies whether to retain the script after it is run.
Valid values: true: The script is retained. You can call the InvokeCommand operation to run the script again, call the DescribeCommands operation to query the script, and call the DeleteCommands operation to delete the script. The retained script takes up the quota of Cloud Assistant scripts. false: The script is not retained. It is automatically deleted after running, without taking up the quota of Cloud Assistant scripts. Default value: false
name
Optional
public java.lang.Object getName();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property name: The name of the script, which supports all character sets.
It can be up to 128 characters in length.
parameters
Optional
public java.lang.Object getParameters();
- Type: com.aliyun.ros.cdk.core.IResolvable OR java.util.Map
Property parameters: The key-value pairs of custom parameters passed in when the script contains custom parameters.
Number of custom parameters: 0 to 10. The key cannot be an empty string. It can be up to 64 characters in length. The value can be an empty string. After the custom parameters and the original script content are Base64 encoded, the total size cannot exceed 16 KB. The set of custom parameter names must be a subset of the parameter set that is defined when you created the script. You can use an empty string to represent the parameters that are not passed in. Default value: null, indicating that this parameter is canceled and customer parameters are disabled.
repeatMode
Optional
public java.lang.Object getRepeatMode();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property repeatMode: Specifies how to run the command.
Valid values:
- Once: immediately runs the command.
- Period: runs the command on a schedule. If you set this parameter to Period, you must specify Frequency.
- NextRebootOnly: runs the command the next time the instance is started.
- *EveryReboot: runs the command every time the instance is started. Default value:
- If you do not specify Frequency, the default value is Once.
- If you specify Frequency, Period is used as the value of RepeatMode regardless of whether RepeatMode is set to Period.
resourceGroupId
Optional
public java.lang.Object getResourceGroupId();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property resourceGroupId: The ID of the resource group to which to assign the command executions.
The instances specified by InstanceIds must belong to the specified resource group.
runAgainOn
Optional
public java.lang.Object getRunAgainOn();
- Type: com.aliyun.ros.cdk.core.IResolvable OR java.util.List
Property runAgainOn: The stage of executing the command again.
sync
Optional
public java.lang.Object getSync();
- Type: java.lang.Boolean OR com.aliyun.ros.cdk.core.IResolvable
Property sync: Whether to invoke synchronously.
tags
Optional
public java.util.List<TagsProperty> getTags();
- Type: java.util.List<TagsProperty>
Property tags: Tags to attach to run_command.
Max support 20 tags to add during create run_command. Each tag with two properties Key and Value, and Key is required.
timeout
Optional
public java.lang.Object getTimeout();
- Type: java.lang.Number OR com.aliyun.ros.cdk.core.IResolvable
Property timeout: The timeout period for script execution.
Unit: seconds. A timeout error occurs when a script cannot be run because the process slows down, a specific module or the Cloud Assistant client does not exist. When the script times out, the script process is forcibly terminated. Default value: 60.
username
Optional
public java.lang.Object getUsername();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property username: The username to use to run the command on instances.
The username can be up to 255 characters in length.
- For Linux instances, the root username is used by default.
- For Windows instances, the System username is used by default. You can also specify other usernames that already exist in the instances to run the command. For security purposes, we recommend that you run Cloud Assistant commands as a regular user.
windowsPasswordName
Optional
public java.lang.Object getWindowsPasswordName();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property windowsPasswordName: The name of the password to use to run the command on Windows instances.
The name can be up to 255 characters in length. If you do not want to use the default System user to run the command on Windows instances, specify both WindowsPasswordName and Username. To mitigate the risk of password leaks, the password is stored in plaintext in Operation Orchestration Service (OOS) Parameter Store, and only the name of the password is passed in by using WindowsPasswordName.
workingDir
Optional
public java.lang.Object getWorkingDir();
- Type: java.lang.String OR com.aliyun.ros.cdk.core.IResolvable
Property workingDir: The running directory of the script in the ECS instance.
Default value: Linux instances: under the home directory of the administrator (root user): /root. Windows instances: under the directory where the process of the Cloud Assistant client is located, such as C:\ProgramData\aliyun\assist$(version).