3 # chkconfig: 2345 98 02
4 # description: PostgreSQL RDBMS
6 # This is an example of a start/stop script for SysV-style init, such
7 # as is used on Linux systems. You should edit some of the variables
8 # and maybe the 'echo' commands.
10 # Place this file at /etc/init.d/postgresql (or
11 # /etc/rc.d/init.d/postgresql) and make symlinks to
12 # /etc/rc.d/rc0.d/K02postgresql
13 # /etc/rc.d/rc1.d/K02postgresql
14 # /etc/rc.d/rc2.d/K02postgresql
15 # /etc/rc.d/rc3.d/S98postgresql
16 # /etc/rc.d/rc4.d/S98postgresql
17 # /etc/rc.d/rc5.d/S98postgresql
18 # Or, if you have chkconfig, simply:
19 # chkconfig --add postgresql
21 # Proper init scripts on Linux systems normally require setting lock
22 # and pid files under /var/run as well as reacting to network
23 # settings, so you should treat this with care.
25 # Original author: Ryan Kirkpatrick <pgsql@rkirkpat.net>
27 # $Header: /cvsroot/pgsql/contrib/start-scripts/linux,v 1.3 2001/07/30 14:52:42 momjian Exp $
32 prefix=/usr/local/pgsql
35 PGDATA="/usr/local/pgsql/data"
37 # Who to run pg_ctl as, should be "postgres".
40 # Where to keep a log file
41 PGLOG="$PGDATA/serverlog"
45 # Check for echo -n vs echo \c
46 if echo '\c' | grep -s c >/dev/null 2>&1 ; then
54 # The path that is to be used for the script
55 PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
57 # What to use to start up the postmaster
58 DAEMON="$prefix/bin/pg_ctl"
62 # Only start if we can find pg_ctl.
63 test -f $DAEMON || exit 0
65 # Parse command line parameters.
68 $ECHO_N "Starting PostgreSQL: "$ECHO_C
69 su - $PGUSER -c "$DAEMON start -D '$PGDATA' -s -l $PGLOG"
73 echo -n "Stopping PostgreSQL: "
74 su - $PGUSER -c "$DAEMON stop -D '$PGDATA' -s -m fast"
78 echo -n "Restarting PostgreSQL: "
79 su - $PGUSER -c "$DAEMON restart -D '$PGDATA' -s -m fast"
83 su - $PGUSER -c "$DAEMON status -D '$PGDATA'"
87 echo "Usage: $0 {start|stop|restart|status}" 1>&2