Create alternate location(s) for databases.
This commit is contained in:
parent
951986c550
commit
b5417a39da
|
@ -0,0 +1,32 @@
|
|||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# Makefile.inc--
|
||||
# Makefile for bin/initlocation
|
||||
#
|
||||
# Copyright (c) 1994, Regents of the University of California
|
||||
#
|
||||
#
|
||||
# IDENTIFICATION
|
||||
# $Header: /cvsroot/pgsql/src/bin/initlocation/Attic/Makefile,v 1.1 1997/11/07 06:21:34 thomas Exp $
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
SRCDIR= ../..
|
||||
include ../../Makefile.global
|
||||
|
||||
SEDSCRIPT= \
|
||||
-e "s^_fUnKy_NAMEDATALEN_sTuFf_^$(NAMEDATALEN)^g" \
|
||||
-e "s^_fUnKy_OIDNAMELEN_sTuFf_^$(OIDNAMELEN)^g"
|
||||
|
||||
all: initlocation
|
||||
|
||||
initlocation: initlocation.sh
|
||||
cp -p initlocation.sh initlocation
|
||||
|
||||
install: initlocation
|
||||
$(INSTALL) $(INSTL_EXE_OPTS) $< $(DESTDIR)$(BINDIR)/$<
|
||||
|
||||
clean:
|
||||
rm -f initlocation
|
||||
|
||||
dep:
|
|
@ -0,0 +1,116 @@
|
|||
#!/bin/sh
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# initarea.sh--
|
||||
# Create (initialize) a secondary Postgres database storage area.
|
||||
#
|
||||
# A database storage area contains individual Postgres databases.
|
||||
#
|
||||
# To create the database storage area, we create a root directory tree.
|
||||
#
|
||||
# Copyright (c) 1994, Regents of the University of California
|
||||
#
|
||||
#
|
||||
# IDENTIFICATION
|
||||
# $Header: /cvsroot/pgsql/src/bin/initlocation/Attic/initlocation,v 1.1 1997/11/07 06:21:38 thomas Exp $
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
CMDNAME=`basename $0`
|
||||
|
||||
while [ "$#" -gt 0 ]
|
||||
do
|
||||
case "$1" in
|
||||
--location=*) PGALTDATA="`echo $1 | sed 's/^--pgdata=//'`"; ;;
|
||||
--username=*) POSTGRES_SUPERUSERNAME="`echo $1 | sed 's/^--username=//'`" ;;
|
||||
|
||||
--location) shift; PGALTDATA="$1"; ;;
|
||||
--username) shift; POSTGRES_SUPERUSERNAME="$1"; ;;
|
||||
|
||||
-u) shift; POSTGRES_SUPERUSERNAME="$1"; ;;
|
||||
-D) shift; PGALTDATA="$1"; ;;
|
||||
-*) badparm=$1; usage=1; ;;
|
||||
*) PGALTDATA="$1"; ;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
if [ ! -z "$badparm" ]; then
|
||||
echo "$CMDNAME: Unrecognized parameter '$badparm'"
|
||||
fi
|
||||
|
||||
if [ ! -z "$usage" ]; then
|
||||
echo "Usage: $CMDNAME [-u SUPERUSER] DATADIR"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Make sure he told us where to build the database area
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
if [ -z "$PGALTDATA" ]; then
|
||||
echo "$CMDNAME: You must identify the target area, where the new data"
|
||||
echo "for this database system can reside. Do this with --location"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
#---------------------------------------------------------------------------
|
||||
# Figure out who the Postgres superuser for the new database system will be.
|
||||
#---------------------------------------------------------------------------
|
||||
|
||||
if [ 1 -eq 0 ]; then
|
||||
if [ -z "$POSTGRES_SUPERUSERNAME" ]; then
|
||||
$POSTGRES_SUPERUSERNAME=pg_id
|
||||
fi
|
||||
|
||||
if [ -z "$POSTGRES_SUPERUSERNAME" ]; then
|
||||
echo "Can't tell what username to use. You don't have the USER"
|
||||
echo "environment variable set to your username and didn't specify the "
|
||||
echo "--username option"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
POSTGRES_SUPERUID=`pg_id $POSTGRES_SUPERUSERNAME`
|
||||
|
||||
if [ $POSTGRES_SUPERUID = NOUSER ]; then
|
||||
echo "Valid username not given. You must specify the username for "
|
||||
echo "the Postgres superuser for the database system you are "
|
||||
echo "initializing, either with the --username option or by default "
|
||||
echo "to the USER environment variable."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ $POSTGRES_SUPERUID -ne `pg_id` -a `pg_id` -ne 0 ]; then
|
||||
echo "Only the unix superuser may initialize a database with a different"
|
||||
echo "Postgres superuser. (You must be able to create files that belong"
|
||||
echo "to the specified unix user)."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "We are initializing the database area with username" \
|
||||
"$POSTGRES_SUPERUSERNAME (uid=$POSTGRES_SUPERUID)."
|
||||
echo "This user will own all the files and must also own the server process."
|
||||
echo
|
||||
fi
|
||||
|
||||
# -----------------------------------------------------------------------
|
||||
# Create the data directory if necessary
|
||||
# -----------------------------------------------------------------------
|
||||
|
||||
# umask must disallow access to group, other for files and dirs
|
||||
umask 077
|
||||
|
||||
if [ ! -d $PGALTDATA ]; then
|
||||
echo "Creating Postgres database system directory $PGALTDATA"
|
||||
echo
|
||||
mkdir $PGALTDATA
|
||||
if [ $? -ne 0 ]; then exit 1; fi
|
||||
fi
|
||||
if [ ! -d $PGALTDATA/base ]; then
|
||||
echo "Creating Postgres database system directory $PGALTDATA/base"
|
||||
echo
|
||||
mkdir $PGALTDATA/base
|
||||
if [ $? -ne 0 ]; then exit 1; fi
|
||||
fi
|
||||
|
||||
exit
|
|
@ -0,0 +1,116 @@
|
|||
#!/bin/sh
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
# initarea.sh--
|
||||
# Create (initialize) a secondary Postgres database storage area.
|
||||
#
|
||||
# A database storage area contains individual Postgres databases.
|
||||
#
|
||||
# To create the database storage area, we create a root directory tree.
|
||||
#
|
||||
# Copyright (c) 1994, Regents of the University of California
|
||||
#
|
||||
#
|
||||
# IDENTIFICATION
|
||||
# $Header: /cvsroot/pgsql/src/bin/initlocation/Attic/initlocation.sh,v 1.1 1997/11/07 06:21:39 thomas Exp $
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
CMDNAME=`basename $0`
|
||||
|
||||
while [ "$#" -gt 0 ]
|
||||
do
|
||||
case "$1" in
|
||||
--location=*) PGALTDATA="`echo $1 | sed 's/^--pgdata=//'`"; ;;
|
||||
--username=*) POSTGRES_SUPERUSERNAME="`echo $1 | sed 's/^--username=//'`" ;;
|
||||
|
||||
--location) shift; PGALTDATA="$1"; ;;
|
||||
--username) shift; POSTGRES_SUPERUSERNAME="$1"; ;;
|
||||
|
||||
-u) shift; POSTGRES_SUPERUSERNAME="$1"; ;;
|
||||
-D) shift; PGALTDATA="$1"; ;;
|
||||
-*) badparm=$1; usage=1; ;;
|
||||
*) PGALTDATA="$1"; ;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
if [ -n "$badparm" ]; then
|
||||
echo "$CMDNAME: Unrecognized parameter '$badparm'"
|
||||
fi
|
||||
|
||||
if [ -n "$usage" ]; then
|
||||
echo "Usage: $CMDNAME [-u SUPERUSER] DATADIR"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Make sure he told us where to build the database area
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
if [ -z "$PGALTDATA" ]; then
|
||||
echo "$CMDNAME: You must identify the target area, where the new data"
|
||||
echo "for this database system can reside. Do this with --location"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
#---------------------------------------------------------------------------
|
||||
# Figure out who the Postgres superuser for the new database system will be.
|
||||
#---------------------------------------------------------------------------
|
||||
|
||||
if [ 1 -eq 0 ]; then
|
||||
if [ -z "$POSTGRES_SUPERUSERNAME" ]; then
|
||||
$POSTGRES_SUPERUSERNAME=pg_id
|
||||
fi
|
||||
|
||||
if [ -z "$POSTGRES_SUPERUSERNAME" ]; then
|
||||
echo "Can't tell what username to use. You don't have the USER"
|
||||
echo "environment variable set to your username and didn't specify the "
|
||||
echo "--username option"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
POSTGRES_SUPERUID=`pg_id $POSTGRES_SUPERUSERNAME`
|
||||
|
||||
if [ $POSTGRES_SUPERUID = NOUSER ]; then
|
||||
echo "Valid username not given. You must specify the username for "
|
||||
echo "the Postgres superuser for the database system you are "
|
||||
echo "initializing, either with the --username option or by default "
|
||||
echo "to the USER environment variable."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ $POSTGRES_SUPERUID -ne `pg_id` -a `pg_id` -ne 0 ]; then
|
||||
echo "Only the unix superuser may initialize a database with a different"
|
||||
echo "Postgres superuser. (You must be able to create files that belong"
|
||||
echo "to the specified unix user)."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "We are initializing the database area with username" \
|
||||
"$POSTGRES_SUPERUSERNAME (uid=$POSTGRES_SUPERUID)."
|
||||
echo "This user will own all the files and must also own the server process."
|
||||
echo
|
||||
fi
|
||||
|
||||
# -----------------------------------------------------------------------
|
||||
# Create the data directory if necessary
|
||||
# -----------------------------------------------------------------------
|
||||
|
||||
# umask must disallow access to group, other for files and dirs
|
||||
umask 077
|
||||
|
||||
if [ ! -d $PGALTDATA ]; then
|
||||
echo "Creating Postgres database system directory $PGALTDATA"
|
||||
echo
|
||||
mkdir $PGALTDATA
|
||||
if [ $? -ne 0 ]; then exit 1; fi
|
||||
fi
|
||||
if [ ! -d $PGALTDATA/base ]; then
|
||||
echo "Creating Postgres database system directory $PGALTDATA/base"
|
||||
echo
|
||||
mkdir $PGALTDATA/base
|
||||
if [ $? -ne 0 ]; then exit 1; fi
|
||||
fi
|
||||
|
||||
exit
|
Loading…
Reference in New Issue