SYNOPSIS

       chpst  [-vP012]  [-u user] [-U user] [-e dir] [-/ root] [-n inc] [-l|-L
       lock] [-m bytes] [-d bytes] [-o n] [-p n] [-f bytes] [-c bytes] prog


DESCRIPTION

       prog consists of one or more arguments.

       chpst changes the process state according to  the  given  options,  and
       runs prog.


OPTIONS

       -u [:]user[:group]
              setuidgid.   Set uid and gid to the user's uid and gid, as found
              in /etc/passwd.  If user is followed by a colon and a group, set
              the  gid  to  group's  gid,  as  found in /etc/group, instead of
              user's gid.  If group consists  of  a  colon-separated  list  of
              group  names, chpst sets the group ids of all listed groups.  If
              user is prefixed with a colon, the user and all group  arguments
              are  interpreted  as uid and gids respectivly, and not looked up
              in the password or group file.  All initial supplementary groups
              are removed.

       -U [:]user[:group]
              envuidgid.   Set  the environment variables $UID and $GID to the
              user's uid and gid, as found in /etc/passwd.  If  user  is  fol-
              lowed  by  a  colon and a group, set $GID to the group's gid, as
              found in /etc/group, instead of user's gid.  If user is prefixed
              with  a  colon,  the user and group arguments are interpreted as
              uid and gid respectivly, and not looked up in  the  password  or
              group file.

       -e dir envdir.  Set various environment variables as specified by files
              in the directory dir: If dir contains a file named k whose first
              line  is  v,  chpst  removes  the  environment  variable k if it
              exists, and then adds the environment variable k with the  value
              v.   The  name k must not contain =.  Spaces and tabs at the end
              of v are removed, and nulls in v are changed  to  newlines.   If
              the  file  k is empty (0 bytes long), chpst removes the environ-
              ment variable k if it exists, without adding a new variable.

       -/ root
              chroot.  Change the root directory to root before starting prog.

       -n inc nice.   Add  inc to the nice(2) value before starting prog.  inc
              must be an integer, and may start with a minus or plus.

       -l lock
              lock.  Open the file lock for writing, and obtain  an  exclusive
              lock on it.  lock will be created if it does not exist.  If lock
              is locked by another process, wait  until  a  new  lock  can  be
              obtained.

              process to n.

       -p n   limit processes.  Limit the number of processes per uid to n.

       -f bytes
              limit output size.  Limit the output file size to bytes bytes.

       -c bytes
              limit core size.  Limit the core file size to bytes bytes.

       -v     verbose.   Print  verbose  messages  to  standard  error.   This
              includes warnings about limits unsupported by the system.

       -P     pgrphack.  Run prog in a new process group.

       -0     Close standard input before starting prog.

       -1     Close standard output before starting prog.

       -2     Close standard error before starting prog.


EXIT CODES

       chpst  exits  100  when  called with wrong options.  It prints an error
       message and exits 111 if it has trouble  changing  the  process  state.
       Otherwise its exit code is the same as that of prog.


EMULATION

       If  chpst is called as envdir, envuidgid, pgrphack, setlock, setuidgid,
       or softlimit, it emulates the functionality of these programs from  the
       daemontools package respectively.


SEE ALSO

       sv(8),   runsv(8),  setsid(2),  runit(8),  runit-init(8),  runsvdir(8),
       runsvchdir(8)

        http://smarden.org/runit/
        http://cr.yp.to/daemontools.html


AUTHOR

       Gerrit Pape <pape@smarden.org>



                                                                      chpst(8)

Man(1) output converted with man2html