mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 15:39:35 +08:00
8f5500e6bd
script. To do this, have pg_ctl pass down its parent shell's PID in an environment variable PG_GRANDPARENT_PID, and teach CreateLockFile() to disregard that PID as a false match if it finds it in postmaster.pid. This allows us to cope with one level of postgres-owned shell process even with pg_ctl in the way, so it's just as safe as starting the postmaster directly. You still have to be careful about how you write the initscript though. Adjust the comments in contrib/start-scripts/ to not deprecate use of pg_ctl. Also, fix the ROTATELOGS option in the OSX script, which was indulging in exactly the sort of unsafe coding that renders this fix pointless :-(. A pipe inside the "sudo" will probably result in more than one postgres-owned process hanging around.
95 lines
2.4 KiB
Bash
95 lines
2.4 KiB
Bash
#! /bin/sh
|
|
|
|
# chkconfig: 2345 98 02
|
|
# description: PostgreSQL RDBMS
|
|
|
|
# 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
|
|
# Or, if you have chkconfig, simply:
|
|
# chkconfig --add postgresql
|
|
#
|
|
# 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>
|
|
|
|
# $PostgreSQL: pgsql/contrib/start-scripts/linux,v 1.9 2009/08/27 16:59:38 tgl Exp $
|
|
|
|
## EDIT FROM HERE
|
|
|
|
# Installation prefix
|
|
prefix=/usr/local/pgsql
|
|
|
|
# Data directory
|
|
PGDATA="/usr/local/pgsql/data"
|
|
|
|
# Who to run the postmaster as, usually "postgres". (NOT "root")
|
|
PGUSER=postgres
|
|
|
|
# Where to keep a log file
|
|
PGLOG="$PGDATA/serverlog"
|
|
|
|
## 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
|
|
|
|
# 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.)
|
|
DAEMON="$prefix/bin/postmaster"
|
|
|
|
# What to use to shut down the postmaster
|
|
PGCTL="$prefix/bin/pg_ctl"
|
|
|
|
set -e
|
|
|
|
# Only start if we can find the postmaster.
|
|
test -x $DAEMON || exit 0
|
|
|
|
# Parse command line parameters.
|
|
case $1 in
|
|
start)
|
|
echo -n "Starting PostgreSQL: "
|
|
su - $PGUSER -c "$DAEMON -D '$PGDATA' &" >>$PGLOG 2>&1
|
|
echo "ok"
|
|
;;
|
|
stop)
|
|
echo -n "Stopping PostgreSQL: "
|
|
su - $PGUSER -c "$PGCTL stop -D '$PGDATA' -s -m fast"
|
|
echo "ok"
|
|
;;
|
|
restart)
|
|
echo -n "Restarting PostgreSQL: "
|
|
su - $PGUSER -c "$PGCTL stop -D '$PGDATA' -s -m fast -w"
|
|
su - $PGUSER -c "$DAEMON -D '$PGDATA' &" >>$PGLOG 2>&1
|
|
echo "ok"
|
|
;;
|
|
reload)
|
|
echo -n "Reload PostgreSQL: "
|
|
su - $PGUSER -c "$PGCTL reload -D '$PGDATA' -s"
|
|
echo "ok"
|
|
;;
|
|
status)
|
|
su - $PGUSER -c "$PGCTL status -D '$PGDATA'"
|
|
;;
|
|
*)
|
|
# Print help
|
|
echo "Usage: $0 {start|stop|restart|reload|status}" 1>&2
|
|
exit 1
|
|
;;
|
|
esac
|
|
|
|
exit 0
|