Documentation

raw - Executes a low-down and dirty SSH command

Synopsis

Executes a low-down and dirty SSH command, not going through the module subsystem. This is useful and should only be done in two cases. The first case is installing python-simplejson on older (Python 2.4 and before) hosts that need it as a dependency to run modules, since nearly all core modules require it. Another is speaking to any devices such as routers that do not have any Python installed. In any other case, using the shell or command module is much more appropriate. Arguments given to raw are run directly through the configured remote shell. Standard output, error output and return code are returned when available. There is no change handler support for this module. This module does not require python on the remote system, much like the script module.

Options

parameter required default choices comments
executable
no
    change the shell used to execute the command. Should be an absolute path to the executable.
    free_form
    yes
      the raw module takes a free form command to run

      Examples

      # Bootstrap a legacy python 2.4 host
      - raw: yum -y install python-simplejson
      
      # Bootstrap a host without python2 installed
      - raw: dnf install -y python2 python2-dnf libselinux-python
      
      # 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
      

      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.

      Note

      If you want to execute a command securely and predictably, it may be better to use the command module instead. Best practices when writing playbooks will follow the trend of using command unless shell is explicitly required. When running ad-hoc commands, use your best judgement.

      This is a Core Module

      For more information on what this means please read Core Modules

      For help in developing on modules, should you be so inclined, please read Community Information & Contributing, Helping Testing PRs and Developing Modules.