2001-02-09 03:53:33 +08:00
|
|
|
#! /bin/sh
|
|
|
|
|
2001-07-30 22:52:42 +08:00
|
|
|
# chkconfig: 2345 98 02
|
|
|
|
# description: PostgreSQL RDBMS
|
|
|
|
|
2001-02-09 03:53:33 +08:00
|
|
|
# This is an example of a start/stop script for SysV-style init, such
|
|
|
|
# as is used on Linux systems. You should edit some of the variables
|
|
|
|
# and maybe the 'echo' commands.
|
|
|
|
#
|
|
|
|
# Place this file at /etc/init.d/postgresql (or
|
|
|
|
# /etc/rc.d/init.d/postgresql) and make symlinks to
|
|
|
|
# /etc/rc.d/rc0.d/K02postgresql
|
|
|
|
# /etc/rc.d/rc1.d/K02postgresql
|
|
|
|
# /etc/rc.d/rc2.d/K02postgresql
|
|
|
|
# /etc/rc.d/rc3.d/S98postgresql
|
|
|
|
# /etc/rc.d/rc4.d/S98postgresql
|
|
|
|
# /etc/rc.d/rc5.d/S98postgresql
|
2001-07-30 22:52:42 +08:00
|
|
|
# Or, if you have chkconfig, simply:
|
|
|
|
# chkconfig --add postgresql
|
2001-02-09 03:53:33 +08:00
|
|
|
#
|
|
|
|
# Proper init scripts on Linux systems normally require setting lock
|
|
|
|
# and pid files under /var/run as well as reacting to network
|
|
|
|
# settings, so you should treat this with care.
|
|
|
|
|
|
|
|
# Original author: Ryan Kirkpatrick <pgsql@rkirkpat.net>
|
|
|
|
|
2010-09-21 04:08:53 +08:00
|
|
|
# contrib/start-scripts/linux
|
2001-02-09 03:53:33 +08:00
|
|
|
|
|
|
|
## EDIT FROM HERE
|
|
|
|
|
|
|
|
# Installation prefix
|
|
|
|
prefix=/usr/local/pgsql
|
|
|
|
|
|
|
|
# Data directory
|
|
|
|
PGDATA="/usr/local/pgsql/data"
|
|
|
|
|
2004-10-02 02:30:25 +08:00
|
|
|
# Who to run the postmaster as, usually "postgres". (NOT "root")
|
2001-02-09 03:53:33 +08:00
|
|
|
PGUSER=postgres
|
|
|
|
|
|
|
|
# Where to keep a log file
|
|
|
|
PGLOG="$PGDATA/serverlog"
|
|
|
|
|
2010-01-12 02:39:32 +08:00
|
|
|
# It's often a good idea to protect the postmaster from being killed by the
|
|
|
|
# OOM killer (which will tend to preferentially kill the postmaster because
|
2012-06-14 03:34:57 +08:00
|
|
|
# of the way it accounts for shared memory). Setting the OOM_SCORE_ADJ value
|
|
|
|
# to -1000 will disable OOM kill altogether. If you enable this, you probably
|
|
|
|
# want to compile PostgreSQL with "-DLINUX_OOM_SCORE_ADJ=0", so that
|
|
|
|
# individual backends can still be killed by the OOM killer.
|
|
|
|
#OOM_SCORE_ADJ=-1000
|
|
|
|
# Older Linux kernels may not have /proc/self/oom_score_adj, but instead
|
|
|
|
# /proc/self/oom_adj, which works similarly except the disable value is -17.
|
|
|
|
# For such a system, enable this and compile with "-DLINUX_OOM_ADJ=0".
|
2010-01-12 02:39:32 +08:00
|
|
|
#OOM_ADJ=-17
|
|
|
|
|
2001-02-09 03:53:33 +08:00
|
|
|
## STOP EDITING HERE
|
|
|
|
|
|
|
|
# The path that is to be used for the script
|
|
|
|
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
|
|
|
|
|
2009-08-28 00:59:38 +08:00
|
|
|
# What to use to start up the postmaster. (If you want the script to wait
|
|
|
|
# until the server has started, you could use "pg_ctl start -w" here.
|
|
|
|
# But without -w, pg_ctl adds no value.)
|
2004-10-02 02:30:25 +08:00
|
|
|
DAEMON="$prefix/bin/postmaster"
|
|
|
|
|
|
|
|
# What to use to shut down the postmaster
|
|
|
|
PGCTL="$prefix/bin/pg_ctl"
|
2001-02-09 03:53:33 +08:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2004-10-02 02:30:25 +08:00
|
|
|
# Only start if we can find the postmaster.
|
2010-02-24 06:15:35 +08:00
|
|
|
test -x $DAEMON ||
|
|
|
|
{
|
|
|
|
echo "$DAEMON not found"
|
|
|
|
if [ "$1" = "stop" ]
|
|
|
|
then exit 0
|
|
|
|
else exit 5
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2001-02-09 03:53:33 +08:00
|
|
|
|
|
|
|
# Parse command line parameters.
|
|
|
|
case $1 in
|
|
|
|
start)
|
2006-07-13 22:44:33 +08:00
|
|
|
echo -n "Starting PostgreSQL: "
|
2012-06-14 03:34:57 +08:00
|
|
|
test x"$OOM_SCORE_ADJ" != x && echo "$OOM_SCORE_ADJ" > /proc/self/oom_score_adj
|
2010-01-12 02:39:32 +08:00
|
|
|
test x"$OOM_ADJ" != x && echo "$OOM_ADJ" > /proc/self/oom_adj
|
2013-04-20 01:28:45 +08:00
|
|
|
su - $PGUSER -c "$DAEMON -D '$PGDATA' &" >>$PGLOG 2>&1
|
2001-02-09 03:53:33 +08:00
|
|
|
echo "ok"
|
|
|
|
;;
|
|
|
|
stop)
|
|
|
|
echo -n "Stopping PostgreSQL: "
|
2013-04-14 11:42:42 +08:00
|
|
|
su - $PGUSER -c "$PGCTL stop -I -D '$PGDATA' -s -m fast"
|
2001-02-09 03:53:33 +08:00
|
|
|
echo "ok"
|
|
|
|
;;
|
|
|
|
restart)
|
|
|
|
echo -n "Restarting PostgreSQL: "
|
2013-04-14 11:42:42 +08:00
|
|
|
su - $PGUSER -c "$PGCTL stop -I -D '$PGDATA' -s -m fast -w"
|
2012-06-14 03:34:57 +08:00
|
|
|
test x"$OOM_SCORE_ADJ" != x && echo "$OOM_SCORE_ADJ" > /proc/self/oom_score_adj
|
2010-01-12 02:39:32 +08:00
|
|
|
test x"$OOM_ADJ" != x && echo "$OOM_ADJ" > /proc/self/oom_adj
|
2004-10-02 02:30:25 +08:00
|
|
|
su - $PGUSER -c "$DAEMON -D '$PGDATA' &" >>$PGLOG 2>&1
|
2001-02-09 03:53:33 +08:00
|
|
|
echo "ok"
|
|
|
|
;;
|
2003-06-12 10:02:24 +08:00
|
|
|
reload)
|
|
|
|
echo -n "Reload PostgreSQL: "
|
2004-10-02 02:30:25 +08:00
|
|
|
su - $PGUSER -c "$PGCTL reload -D '$PGDATA' -s"
|
2003-06-12 10:02:24 +08:00
|
|
|
echo "ok"
|
2003-07-27 04:42:55 +08:00
|
|
|
;;
|
2001-02-09 03:53:33 +08:00
|
|
|
status)
|
2004-10-02 02:30:25 +08:00
|
|
|
su - $PGUSER -c "$PGCTL status -D '$PGDATA'"
|
2001-02-09 03:53:33 +08:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
# Print help
|
2003-06-12 10:02:24 +08:00
|
|
|
echo "Usage: $0 {start|stop|restart|reload|status}" 1>&2
|
2001-02-09 03:53:33 +08:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
exit 0
|