ABCDEFGHIJKLMNOPQRSTUVWXYZ

rexec

REXEC(1)                                                              REXEC(1)



NAME
       rexec -- remote execution client for an exec server

SYNOPSIS
       rexec [ -abcdhns -l username -p password ] host command

DESCRIPTION
       Rexec  calls  the  rexec(3)  routine  to act as a client for the remote
       host's rexecd(8) server.

       It asks that ``command'' be run  on  the  host  computer,  using  user-
       name/password authentication. See rexec(3) and rexecd(8) for details of
       the protocol.

OPTIONS
       Rexec accepts several options, but only three are  likely  to  be  very
       useful:

       -l username

              Set the log-in name on the remote host to username.

       -p password

              Provide  the  password for the remote account.  The command line
              argument will be blanked after being parsed, to prevent it  from
              being  seen with ps(1).  However, it is still not very secure to
              type the password on the command line.  In particular,  be  sure
              that the shell's history file is protected.

       -n     Explicitly prompt for name and password, even if provided in the
              environment, in the $HOME/.netrc file, or in  the  environmental
              variables REXEC_USER and REXEC_PASS.

       Other  options  that might be useful with non-standard remote exec dae-
       mons, or to debug connections:

       -a     Do not set up an auxiliary channel for standard error from  com-
              mand;  the  remote  standard  error  and  output  are  then both
              returned on the local standard output.  By default,  rexec  asks
              that a separate channel be set up for diagnostic output from the
              remote command.

       -b     Use signal handling as in BSD rsh(1).  Only the signals  SIGINT,
              SIGQUIT,  and SIGTERM are echoed to the remote process.  They do
              not remain raised locally, so rexec waits for the remote command
              to  shutdown  its  side  of the socket.  Also, CNTRL-Z will only
              suspend execution locally--the remote command  may  continue  to
              run.

       -c     Do  not  close  remote  standard input when local standard input
              closes.  Normally the standard input to the  remote  command  is
              closed when the local standard input is closed.

       -d     Turn on debugging information. In particular the command sent to
              the remote host will be echoed.

       -h     Print a usage message.

       -s     Do not echo signals received by the rexec onto the  remote  pro-
              cess.   Normally,  signals which can be trapped are passed on to
              the remote process; then, when  you  type  CNTRL-C,  the  remote
              process terminates as well.

USERNAME AND PASSWORD
       Rexec(1) searches for the username and password in the following order:

              1. If -n is given on the command line, the user will  always  be
              prompted  for  both,  even if they are also given on the command
              line.

              2. The command line will be parsed

              3. If the environmental variables REXEC_USER or  REXEC_PASS  are
              defined, they will define the username or password.

              4.  The  $HOME/.netrc  file  will be searched.  See ftp(1) for a
              description of this file's format.

              5. Finally, the user will be prompted if either the username  or
              password remains undefined.


SECURITY
       Users  of  this  command  should be aware that rexec(3) transmits their
       password to the remote host clear text, not encrypted.  If the  network
       is not secure to the remote host, the password can be comprimised.


SIGNALS
       Without  the  -b option, all signals which can be handled are echoed to
       the remote process.  Afterwards, however, they  remain  raised  in  the
       local  process.   Typically,  this  means that rexec(1) will exit after
       receiving a fatal signal, even if the remote process  has  arranged  to
       handle or ignore it.

       Differing  operating  systems use differing signal numbers; for example
       AIX and SunOS use 18 for SIGTSTP (^Z), while Linux uses 20.  Therefore,
       it  may  have a different effect remotely than locally.  In particular,
       typing CNTL-Z may not suspend the execution of the remote process.

EXAMPLE
       rexec othermachine cat ">remote_file; date" <local_file

       will send local_file to the othermachine as remote_file.


BUGS
       Please send bug reports, system incompatibilities, and  job  offers  to
       the author.

SEE ALSO
       rexec(3), rexecd(8), rsh(1)

AUTHOR
       Michael Sadd
       mas22@cornell.edu
       http://www.tc.cornell.edu/~sadd/

       Thanks  to  Orange  Gopher  (2/10/97)  and  Johannes  Plass (plass@dip-
       mza.physik.uni-mainz.de, Oct. 17 1996) for useful suggestions.



                               February 14, 1997                      REXEC(1)