lunar (1) fab.1.gz

Provided by: fabric_2.6.0-1_all bug

NAME

       fab - Simple Pythonic remote deployment tool

SYNOPSIS

        fab [commands ...]

DESCRIPTION

       The  most  common  method  for  utilizing  Fabric is via its command-line tool, fab, which
       should have been placed on your shell's executable path when  Fabric  was  installed.  fab
       tries  hard  to  be  a good Unix citizen, using a standard style of command-line switches,
       help output, and so forth.

USAGE

   Basic use
       In its most simple form, fab may be called with no options at all, and with  one  or  more
       arguments, which should be task names, e.g.:

          $ fab task1 task2

       This  will  run  task1  followed by task2, assuming that Fabric was able to find a fabfile
       nearby containing Python functions with those names.

       However, it's possible to expand this simple usage into something more flexible, by  using
       the provided options and/or passing arguments to individual tasks.

   Arbitrary remote shell commands
       New in version 0.9.2.

       Fabric leverages a lesser-known command line convention and may be called in the following
       manner:

          $ fab [options] -- [shell command]

       where everything after the -- is turned into a temporary run call, and is not  parsed  for
       fab  options.  If  you've  defined a host list at the module level or on the command line,
       this usage will act like a one-line anonymous task.

       For example, let's say you just wanted to get the kernel info for a bunch of systems;  you
       could do this:

          $ fab -H system1,system2,system3 -- uname -a

       which would be literally equivalent to the following fabfile:

          from fabric.api import run

          def anonymous():
              run("uname -a")

       as if it were executed thusly:

          $ fab -H system1,system2,system3 anonymous

       Most  of  the  time you will want to just write out the task in your fabfile (anything you
       use once, you're likely to use again) but this feature  provides  a  handy,  fast  way  to
       quickly dash off an SSH-borne command while leveraging your fabfile's connection settings.

   Command-line options
       A  quick  overview  of  all  possible command line options can be found via fab --help. If
       you're looking for details on a specific option, we go into detail below.

       NOTE:
          fab uses Python's optparse library, meaning that it honors typical Linux or  GNU  style
          short  and long options, as well as freely mixing options and arguments. E.g. fab task1
          -H hostname task2 -i path/to/keyfile is just as valid as the more  straightforward  fab
          -H hostname -i path/to/keyfile task1 task2.

       -a, --no_agent
              Sets  env.no_agent to True, forcing our SSH layer not to talk to the SSH agent when
              trying to unlock private key files.

              New in version 0.9.1.

       -A, --forward-agent
              Sets env.forward_agent to True, enabling agent forwarding.

              New in version 1.4.

       --abort-on-prompts
              Sets env.abort_on_prompts to True, forcing Fabric to abort whenever it would prompt
              for input.

              New in version 1.1.

       -c RCFILE, --config=RCFILE
              Sets  env.rcfile  to  the given file path, which Fabric will try to load on startup
              and use to update environment variables.

       -d COMMAND, --display=COMMAND
              Prints the entire docstring for the given task, if there is one. Does not currently
              print out the task's function signature, so descriptive docstrings are a good idea.
              (They're always a good idea, of course -- just moreso here.)

       --connection-attempts=M, -n M
              Set number of times to attempt connections. Sets env.connection_attempts.

              SEE ALSO:
                 env.connection_attempts, env.timeout

              New in version 1.4.

       -D, --disable-known-hosts
              Sets env.disable_known_hosts to True, preventing Fabric from loading the user's SSH
              known_hosts file.

       -f FABFILE, --fabfile=FABFILE
              The  fabfile name pattern to search for (defaults to fabfile.py), or alternately an
              explicit file path to load as the fabfile (e.g.  /path/to/my/fabfile.py.)

              SEE ALSO:
                 fabfiles

       -F LIST_FORMAT, --list-format=LIST_FORMAT
              Allows  control  over  the  output  format  of  --list.  short  is  equivalent   to
              --shortlist,  normal  is the same as simply omitting this option entirely (i.e. the
              default), and nested prints out a nested namespace tree.

              New in version 1.1.

              SEE ALSO:
                 --shortlist, --list

       -g HOST, --gateway=HOST
              Sets env.gateway to HOST host string.

              New in version 1.5.

       -h, --help
              Displays a standard help message, with all possible options and a brief overview of
              what they do, then exits.

       --hide=LEVELS
              A comma-separated list of output levels to hide by default.

       -H HOSTS, --hosts=HOSTS
              Sets env.hosts to the given comma-delimited list of host strings.

       -x HOSTS, --exclude-hosts=HOSTS
              Sets  env.exclude_hosts  to  the given comma-delimited list of host strings to then
              keep out of the final host list.

              New in version 1.1.

       -i KEY_FILENAME
              When set to a file path, will load the given file as an SSH identity file  (usually
              a  private  key.)  This option may be repeated multiple times. Sets (or appends to)
              env.key_filename.

       -I, --initial-password-prompt
              Forces a password prompt at the start of the session (after fabfile load and option
              parsing, but before executing any tasks) in order to pre-fill env.password.

              This  is  useful  for  fire-and-forget runs (especially parallel sessions, in which
              runtime input is not possible) when setting  the  password  via  --password  or  by
              setting env.password in your fabfile, is undesirable.

              NOTE:
                 The  value  entered  into  this  prompt  will  overwrite  anything  supplied via
                 env.password at module level, or via --password.

              SEE ALSO:
                 password-management

       -k     Sets env.no_keys to True, forcing the SSH layer to not look  for  SSH  private  key
              files in one's home directory.

              New in version 0.9.1.

       --keepalive=KEEPALIVE
              Sets  env.keepalive  to  the  given  (integer)  value,  specifying an SSH keepalive
              interval.

              New in version 1.1.

       --linewise
              Forces output to be buffered line-by-line instead of byte-by-byte. Often useful  or
              required for parallel execution.

              New in version 1.3.

       -l, --list
              Imports  a  fabfile  as  normal, but then prints a list of all discovered tasks and
              exits. Will also print the first line of each task's docstring, if it has one, next
              to it (truncating if necessary.)

              Changed in version 0.9.1: Added docstring to output.

              SEE ALSO:
                 --shortlist, --list-format

       -p PASSWORD, --password=PASSWORD
              Sets env.password to the given string; it will then be used as the default password
              when making SSH connections or calling the sudo program.

              SEE ALSO:
                 --initial-password-prompt

       -P, --parallel
              Sets env.parallel to True, causing tasks to run in parallel.

              New in version 1.3.

              SEE ALSO:
                 /usage/parallel

       --no-pty
              Sets env.always_use_pty to False, causing all run/sudo calls to behave  as  if  one
              had specified pty=False.

              New in version 1.0.

       -r, --reject-unknown-hosts
              Sets  env.reject_unknown_hosts  to True, causing Fabric to abort when connecting to
              hosts not found in the user's SSH known_hosts file.

       -R ROLES, --roles=ROLES
              Sets env.roles to the given comma-separated list of role names.

       --set KEY=VALUE,...
              Allows you to set default values for arbitrary Fabric env vars. Values set this way
              have  a  low  precedence -- they will not override more specific env vars which are
              also specified on the command line. E.g.:

                 fab --set password=foo --password=bar

              will result in env.password = 'bar', not 'foo'

              Multiple   KEY=VALUE   pairs   may   be    comma-separated,    e.g.    fab    --set
              var1=val1,var2=val2.

              Other  than  basic string values, you may also set env vars to True by omitting the
              =VALUE (e.g. fab --set KEY), and you may set values to the empty string (and thus a
              False-equivalent  value)  by  keeping the equals sign, but omitting VALUE (e.g. fab
              --set KEY=.)

              New in version 1.4.

       -s SHELL, --shell=SHELL
              Sets env.shell to the given string, overriding the default shell  wrapper  used  to
              execute remote commands.

       --shortlist
              Similar  to  --list,  but  without  any embellishment, just task names separated by
              newlines with no indentation or docstrings.

              New in version 0.9.2.

              SEE ALSO:
                 --list

       --show=LEVELS
              A comma-separated list of output levels to be added to  those  that  are  shown  by
              default.

              SEE ALSO:
                 run, sudo

       --ssh-config-path
              Sets env.ssh_config_path.

              New in version 1.4.

              SEE ALSO:
                 ssh-config

       --skip-bad-hosts
              Sets env.skip_bad_hosts, causing Fabric to skip unavailable hosts.

              New in version 1.4.

       --skip-unknown-tasks
              Sets env.skip_unknown_tasks, causing Fabric to skip unknown tasks.

              SEE ALSO:
                 env.skip_unknown_tasks

       --timeout=N, -t N
              Set connection timeout in seconds. Sets env.timeout.

              SEE ALSO:
                 env.timeout, env.connection_attempts

              New in version 1.4.

       --command-timeout=N, -T N
              Set remote command timeout in seconds. Sets env.command_timeout.

              SEE ALSO:
                 env.command_timeout,

              New in version 1.6.

       -u USER, --user=USER
              Sets  env.user  to  the  given string; it will then be used as the default username
              when making SSH connections.

       -V, --version
              Displays Fabric's version number, then exits.

       -w, --warn-only
              Sets env.warn_only to True, causing Fabric to continue execution even when commands
              encounter error conditions.

       -z, --pool-size
              Sets  env.pool_size,  which specifies how many processes to run concurrently during
              parallel execution.

              New in version 1.3.

              SEE ALSO:
                 /usage/parallel

   Per-task arguments
       The options given in command-line-options apply to the invocation of fab as a whole;  even
       if  the  order  is  mixed  around,  options  still  apply  to  all  given  tasks  equally.
       Additionally, since tasks are just Python functions,  it's  often  desirable  to  pass  in
       arguments to them at runtime.

       Answering  both  these  needs  is  the concept of "per-task arguments", which is a special
       syntax you can tack onto the end of any task name:

       • Use a colon (:) to separate the task name from its arguments;

       • Use commas (,) to separate arguments from  one  another  (may  be  escaped  by  using  a
         backslash, i.e. \,);

       • Use  equals  signs (=) for keyword arguments, or omit them for positional arguments. May
         also be escaped with backslashes.

       Additionally, since this process involves string parsing, all values will end up as Python
       strings,  so plan accordingly. (We hope to improve upon this in future versions of Fabric,
       provided an intuitive syntax can be found.)

       For example, a "create a new user" task might be defined like so  (omitting  most  of  the
       actual logic for brevity):

          def new_user(username, admin='no', comment="No comment provided"):
              print("New User (%s): %s" % (username, comment))
              pass

       You can specify just the username:

          $ fab new_user:myusername

       Or treat it as an explicit keyword argument:

          $ fab new_user:username=myusername

       If both args are given, you can again give them as positional args:

          $ fab new_user:myusername,yes

       Or mix and match, just like in Python:

          $ fab new_user:myusername,admin=yes

       The print call above is useful for illustrating escaped commas, like so:

          $ fab new_user:myusername,admin=no,comment='Gary\, new developer (starts Monday)'

       NOTE:
          Quoting  the  backslash-escaped  comma  is  required,  as not doing so will cause shell
          syntax errors. Quotes are also needed whenever an argument involves other shell-related
          characters such as spaces.

       All  of the above are translated into the expected Python function calls. For example, the
       last call above would become:

          >>> new_user('myusername', admin='yes', comment='Gary, new developer (starts Monday)')

   Roles and hosts
       As mentioned in the section on task execution, there are a  handful  of  per-task  keyword
       arguments  (host,  hosts,  role and roles) which do not actually map to the task functions
       themselves, but are used for setting per-task host and/or role lists.

       These special kwargs are removed from the args/kwargs sent to the  task  function  itself;
       this  is  so  that you don't run into TypeErrors if your task doesn't define the kwargs in
       question. (It also means that if you do define arguments with these names,  you  won't  be
       able to specify them in this manner -- a regrettable but necessary sacrifice.)

       NOTE:
          If  both  the  plural  and  singular  forms of these kwargs are given, the value of the
          plural will win out and the singular will be discarded.

       When using the plural form of these arguments, one must use semicolons  (;)  since  commas
       are  already  being  used to separate arguments from one another.  Furthermore, since your
       shell is likely to consider semicolons a special character, you'll want to quote the  host
       list string to prevent shell interpretation, e.g.:

          $ fab new_user:myusername,hosts="host1;host2"

       Again,  since  the hosts kwarg is removed from the argument list sent to the new_user task
       function, the actual Python invocation would be new_user('myusername'), and  the  function
       would be executed on a host list of ['host1', 'host2'].

   Settings files
       Fabric  currently  honors  a  simple user settings file, or fabricrc (think bashrc but for
       fab) which should contain one or more key-value pairs, one per line. These lines  will  be
       subject  to  string.split('='),  and  thus  can  currently  only be used to specify string
       settings. Any such key-value pairs will be used to update env when fab runs, and is loaded
       prior to the loading of any fabfile.

       By  default, Fabric looks for ~/.fabricrc, and this may be overridden by specifying the -c
       flag to fab.

       For example, if your typical SSH login username differs from  your  workstation  username,
       and  you don't want to modify env.user in a project's fabfile (possibly because you expect
       others to use it as well) you could write a fabricrc file like so:

          user = ssh_user_name

       Then, when running fab, your fabfile would load up with env.user set  to  'ssh_user_name'.
       Other  users  of that fabfile could do the same, allowing the fabfile itself to be cleanly
       agnostic regarding the default username.

AUTHOR

       Fabric was written by Christian Vest Hansen <karmazilla@gmail.com>.

       This manual was generated based  on  Fabric's  documentation  by  Andrew  Starr-Bochicchio
       <asb@debian.org> for the Debian project (but may be used by others).

SEE ALSO

              ssh(1)

                                        September 15, 2015                                 FAB(1)