raw - Executes a low-down and dirty SSH command

Synopsis

Parameters

Parameter Choices/Defaults Comments
executable
change the shell used to execute the command. Should be an absolute path to the executable.
when using privilege escalation (become), a default shell will be assigned if one is not provided as privilege escalation requires a shell.
free_form
required
the raw module takes a free form command to run. There is no parameter actually named 'free form'; see the examples!

Notes

Note

  • If using raw from a playbook, you may need to disable fact gathering using gather_facts: no if you’re using raw to bootstrap python onto the machine.
  • If you want to execute a command securely and predictably, it may be better to use the command or shell modules instead.
  • the environment keyword does not work with raw normally, it requires a shell which means it only works if executable is set or using the module with privilege escalation (become).
  • This module is also supported for Windows targets.

Examples

- name: Bootstrap a host without python2 installed
  raw: dnf install -y python2 python2-dnf libselinux-python

- name: Run a command that uses non-posix shell-isms (in this example /bin/sh doesn't handle redirection and wildcards together but bash does)
  raw: cat < /tmp/*txt
  args:
    executable: /bin/bash

- name: safely use templated variables. Always use quote filter to avoid injection issues.
  raw: "{{package_mgr|quote}} {{pkg_flags|quote}} install {{python|quote}}"

Status

This module is flagged as stableinterface which means that the maintainers for this module guarantee that no backward incompatible interface changes will be made.

Maintenance

This module is flagged as core which means that it is maintained by the Ansible Core Team. See Module Maintenance & Support for more info.

For a list of other modules that are also maintained by the Ansible Core Team, see here.

Support

For more information about Red Hat’s support of this module, please refer to this Knowledge Base article

Author

  • Ansible Core Team
  • Michael DeHaan

Hint

If you notice any issues in this documentation you can edit this document to improve it.