Builtin Node Steps
Builtin Node Steps
Command step
Use the command step to call system commands. Enter any command string you would type at the terminal on the remote hosts.
Script step
Execute the supplied shell script content. Optionally, can pass an argument to the script specified in the lower text field.
Warning
If an exception is thrown with the message Cannot run program, error = 26 Text file busy
when executing the script step, a node attribute enable-sync=true
can be configured to enable a sync
command to be executed (in background) before executing the script, avoiding this scenario.
Script file step
Executes the script file local to the sever to the filtered Node set. Arguments can be passed to the script by specifying them in the lower text field.
Script URL step
Downloads a script from a URL, and executes it to the filtered Node set. Arguments can be passed to the script by specifying them in the lower text field.
The URL can contain Context Variables that will be expanded at runtime.
Job reference step
To call another saved Job, create a Job Reference step. Enter the name of the Job and its group.
The Job Reference form provides a Job browser to make it easier to select from the existing set of saved Jobs. Click the "Choose A Job..." link and navigate to the desired Job.
Finally, if the Job defines Options, you can specify them in the commandline arguments text field and can include variable expansion to pass any input options for the current job. Format:
-optname <value> -optname <value> ...
The format for specifying options is exactly the same as you would pass to the run
commandline tool, and you can substitute values of input options to the current job. For example:
-opt1 something -opt2 ${option.opt2}
This would set the value "something" for the Job's "opt1" option, and then pass the "opt2" option directly from the top-level job to the Job reference.
This is similar to calling the other Job with [run]:
run [filter-options] -j group/jobname -- -opt1 something -opt2 somethingelse
If the Job has required Options that are not specified on the arguments line, then a "defaultValue" of that option will be used if it is defined. If a required option does not have a default value, then the execution will fail because the option is not specified.
Job References can be run as either Node Steps or Workflow Steps (see Workflow Steps : Types of Steps). When you choose to use a Job Reference as a Node Step, you can use the Node context variables within the arguments string to the Job.
Overriding Node Filters
You can override the Node Filters used in the referenced Job. Click the "Override Node Filters?" button to expand the Node Filter area.
Enter a new filter in the "Node Filter" input field to preview the matched nodes.
Once you enter a new filter, you can modify the other aspects for the Node Dispatching used by the Job Reference:
- Thread Count
- Node failure behavior
- Node Rank attribute
- Node Rank order
Copy File step
Copy a file to a destination on a remote node.
Configuration
- Source Path
- Path on the rundeck server for the file or base directory (recursive/wildcard search).
- Destination Path
- Path on the remote node for the file destination. If the path ends with a /, the same filename as the source will be used.
- Pattern
- Wildcard pattern (optional). E.g:
**/*.txt
- Recursive copy
- Recursively copy source dir, or matched files and dirs to the destination path.
- Print transfer information
- Log information about the file copy
Local Command step
Run a command locally on the server
Configuration
- Command
- The command (runs locally)
Data Node step
Produce data values for a node.
Configuration
- Data
- Properties formatted data to set for the current node
- Format
- Format for the data. One of:
properties
,json
, oryaml
HTTP Node Step
Performs an HTTP Request with or without authentication (per node)
Configuration
- Remote URL
- The URL to which to make the request.
Tips
This plugin doesn't support unsafe characters. If you get this error message: Illegal character in scheme name at index
means that you're using an unsafe character. All unsafe characters must always be encoded within a URL. For more information on unsafe characters see IETF | Internet Engineering Task Force
- HTTP Method
- The method that you want to be performed on the URL
- Headers
- Any headers you wish to include
- Body
- Any body you want
- Request Timeout
- How long to wait for the request to complete before failing
Authentication
- Authentication
- Method of authentication to use (Basic or OAuth 2.0)
- Username/Client ID
- Username used for authentication
- Password/Secret Key
- The password or secret key file used for authentication
- Oauth Token URL:
- If using OAuth, provide the endpoint URL at which to obtain tokens
- OAuth Validate URL
- If using OAuth, provide the endpoint URL at which to obtain validate token responses
Notes
Advanced Script options
For Script steps, Script file steps, and Script URL steps, you can specify an optional Invocation string to declare how the script should be executed.
Click on the "Advanced" link to reveal the input.
Enter a command that will be used as the invocation to run the script, by including ${scriptfile}
to define where the resulting file will appear in the invocation command. For example, you can execute the script using sudo
by entering:
sudo -u username ${scriptfile}
This will then allow your script to make use of Sudo authentication.
The effective commandline for your script will become:
sudo -u username [scriptfile] arguments ...
If necessary, you can check the "Quote arguments to script invocation string?" checkbox, which will then quote both the scriptfile and arguments before passing to the invocation command:
[invocation string] "[scriptfile] arguments ..."
Tips
If an specific encoding is needed when using power shell executor, you can set this through the invocation string:
powershell [Console]::OutputEncoding = [Text.UTF8Encoding]::utf8 ; "[scriptfile] arguments ..."
Changing the File extension
You can also change the file extension set on the temporary file when it is invoked. This might be necessary if your command expects a file with a certain extension.
Set the "File Extension" field to the desired extension. The .
is optional, e.g. .ps
or sh
. The default is determined by the type of target node. Unix uses .sh
and Windows uses .bat
.
Quoting arguments to steps
When you define a Command or arguments to any Script or Job reference step, your arguments are interpreted as a space-separated sequence of strings. If you need to use spaces or quotes within the argument, here are some rules for quoting arguments:
- If you have an argument with a space character, you can use either double or single quotes:
"my argument"
: interpreted asmy argument
'my argument'
: interpreted asmy argument
- If you need to embed quotes within a quoted argument, you can wrap it in the opposite kind of quote (double or single):
'"double quotes"'
: interpreted as"double quotes"
"'single quotes'"
: interpreted as'single quotes'
- Or use doubled-up quote characters
"""double quotes"""
: interpreted as"double quotes"
'''single quotes'''
: interpreted as'single quotes'
Tips
On version 3.4.1 quoting in jobs was changed. If you want to keep using the same quoting behavior as previous versions, you can add a new property in "framework.properties" file.
rundeck.feature.quoting.backwardCompatible=true