cookbook 'remote-exec', '= 0.1.1'
remote-exec (3) Versions 0.1.1 Follow0
remote_execute resource for Chef
cookbook 'remote-exec', '= 0.1.1', :supermarket
knife supermarket install remote-exec
knife supermarket download remote-exec
remote-exec cookbook
This cookbook implements remote_execute resource. As its name implies, the resource
executes a command on a remote server using ssh.
Requirements
Tested only with Chef 12. The cookbook uses Net:SSH Ruby module, which is expected
to be installed. I think, it is usually the case, if you have chef-client.
Resources
remote_execute 'i wanna do something' do command 'ls -l' address '127.0.0.1' user 'root' password 'dontknow' end
Syntax:
remote_execute 'name' do address String # command String # defaults to name returns Integer, Array # password String # user String # timeout Integer # default: 60 not_if_remote String # only_if_remote String # action Symbol # defaults to :run end
Actions
The resource has the following actions:
:nothing
Prevent a command from running. Does nothing ;-)
:run
Default. Run a command.
Properties
The resource has the following properties:
command
The name of the command to be executed. Default value: the name
of the resource block
returns
The return value for a command. This may be an array of accepted values. An exception is raised when the return value(s) do not match. Default value: 0
.
address
The address of the remote server.
user
The username used to connect to the remote server.
password
The password for the user to connect to the remote server. If not specified, Net:SSH tries to connect using SSH keys, and if it doesn't help, asks for a password.
timeout
Timeout for SSH session. Default is 60 seconds.
Guards
There are 2 additional guards, implemented in the resource:
not_if_remote
It prevents a resource from executing, if the specified condition (command) returns on the remote server true (0).
only_if_remote
It allows a resource to execute, only if the specified condition (command) returns on the remote server true (0).
Example
remote_execute 'create a file' do command 'touch /tmp/tempfile' address '192.168.0.1' user 'root' password 'dontknow' only_if_remote 'ls /dev/null' end
ChangeLog
v0.1.1 2016-11-28
- timeout option added
v0.1.0 2016-11-07
- Initial release
Dependent cookbooks
This cookbook has no specified dependencies.
Contingent cookbooks
There are no cookbooks that are contingent upon this one.
Collaborator Number Metric
0.1.1 failed this metric
Failure: Cookbook has 0 collaborators. A cookbook must have at least 2 collaborators to pass this metric.
Foodcritic Metric
0.1.1 passed this metric
0.1.1 failed this metric
0.1.1 passed this metric