initdb.sh fix from Peter.
This commit is contained in:
parent
83bad7c063
commit
ac00256ceb
|
@ -26,7 +26,7 @@
|
|||
#
|
||||
#
|
||||
# IDENTIFICATION
|
||||
# $Header: /cvsroot/pgsql/src/bin/initdb/Attic/initdb.sh,v 1.66 1999/12/17 01:05:30 momjian Exp $
|
||||
# $Header: /cvsroot/pgsql/src/bin/initdb/Attic/initdb.sh,v 1.67 1999/12/17 01:16:03 momjian Exp $
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
|
@ -152,40 +152,27 @@ do
|
|||
exit 100
|
||||
fi
|
||||
;;
|
||||
--help)
|
||||
usage=t
|
||||
;;
|
||||
-\?)
|
||||
usage=t
|
||||
;;
|
||||
*)
|
||||
echo "Unrecognized option '$1'. Try -? for help."
|
||||
exit 100
|
||||
echo "Unrecognized option '$1'. Syntax is:"
|
||||
if [ -z "$MULTIBYTE" ];then
|
||||
echo "initdb [-t | --template] [-d | --debug]" \
|
||||
"[-n | --noclean]" \
|
||||
"[-u SUPERUSER | --username=SUPERUSER]" \
|
||||
"[-r DATADIR | --pgdata=DATADIR]" \
|
||||
"[-l LIBDIR | --pglib=LIBDIR]"
|
||||
else
|
||||
echo "initdb [-t | --template] [-d | --debug]" \
|
||||
"[-n | --noclean]" \
|
||||
"[-u SUPERUSER | --username=SUPERUSER]" \
|
||||
"[-r DATADIR | --pgdata=DATADIR]" \
|
||||
"[-l LIBDIR | --pglib=LIBDIR]" \
|
||||
"[-e ENCODING | --pgencoding=ENCODING]"
|
||||
fi
|
||||
exit 100
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
if [ "$usage" ]; then
|
||||
echo ""
|
||||
echo "Usage: $CMDNAME [options]"
|
||||
echo ""
|
||||
echo " -t, --template "
|
||||
echo " -d, --debug "
|
||||
echo " -n, --noclean "
|
||||
echo " -u SUPERUSER, --username=SUPERUSER "
|
||||
echo " -r DATADIR, --pgdata=DATADIR "
|
||||
echo " -l LIBDIR, --pglib=LIBDIR "
|
||||
|
||||
if [ -n "$MULTIBYTE" ]; then
|
||||
echo " -e ENCODING, --pgencoding=ENCODING"
|
||||
fi
|
||||
|
||||
echo " -?, --help "
|
||||
echo ""
|
||||
|
||||
exit 100
|
||||
fi
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Make sure he told us where to find the Postgres files.
|
||||
#-------------------------------------------------------------------------
|
||||
|
@ -282,6 +269,300 @@ echo "We are initializing the database system with username" \
|
|||
echo "This user will own all the files and must also own the server process."
|
||||
echo
|
||||
|
||||
# -----------------------------------------------------------------------
|
||||
# Create the data directory if necessary
|
||||
- 26,318 ----
|
||||
#
|
||||
#
|
||||
# IDENTIFICATION
|
||||
# $Header: /cvsroot/pgsql/src/bin/initdb/Attic/initdb.sh,v 1.67 1999/12/17 01:16:03 momjian Exp $
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
function exit_nicely () {
|
||||
echo
|
||||
echo "$CMDNAME failed."
|
||||
if [ $noclean -eq 0 ]; then
|
||||
echo "Removing $PGDATA."
|
||||
rm -rf $PGDATA || echo "Failed."
|
||||
else
|
||||
echo "Data directory $PGDATA will not be removed at user's request."
|
||||
fi
|
||||
exit 1
|
||||
}
|
||||
|
||||
|
||||
CMDNAME=`basename $0`
|
||||
if [ $EUID -eq 0 ]; then
|
||||
echo "You cannot run $CMDNAME as root. Please log in (using, e.g., 'su')"
|
||||
echo "as the (unprivileged) user that will own the server process."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
EffectiveUser=`id -n -u 2> /dev/null` || EffectiveUser=`whoami 2> /dev/null`
|
||||
TEMPFILE="/tmp/initdb.$$"
|
||||
|
||||
#
|
||||
# Find out where we're located
|
||||
#
|
||||
if echo "$0" | grep -s '/' >& /dev/null ; then
|
||||
# explicit dir name given
|
||||
PGPATH=`echo $0 | sed 's,/[^/]*$,,'` # (dirname command is not portable)
|
||||
else
|
||||
# look for it in PATH ('which' command is not portable)
|
||||
for dir in `echo $PATH | sed 's/:/ /g'` ; do
|
||||
# empty entry in path means current dir
|
||||
[ -z "$dir" ] && dir='.'
|
||||
if [ -f "$dir/$CMDNAME" ]; then
|
||||
PGPATH="$dir"
|
||||
break
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
# Check if needed programs actually exist in path
|
||||
for prog in postgres pg_version ; do
|
||||
if [ ! -x "$PGPATH/$prog" ]; then
|
||||
echo "The program $prog needed by $CMDNAME could not be found. It was"
|
||||
echo "expected at:"
|
||||
echo " $PGPATH/$prog"
|
||||
echo "If this is not the correct directory, please start $CMDNAME"
|
||||
echo "with a full search path. Otherwise make sure that the program"
|
||||
echo "was installed successfully."
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
|
||||
# 0 is the default (non-)encoding
|
||||
MULTIBYTEID=0
|
||||
# This is placed here by configure --with-mb=XXX.
|
||||
MULTIBYTE=__MULTIBYTE__
|
||||
|
||||
# Set defaults:
|
||||
debug=0
|
||||
noclean=0
|
||||
template_only=0
|
||||
|
||||
|
||||
# Note: There is a single compelling reason that the name of the database
|
||||
# superuser be the same as the Unix user owning the server process:
|
||||
# The single user postgres backend will only connect as the database
|
||||
# user with the same name as the Unix user running it. That's
|
||||
# a security measure. It might change in the future (why?), but for
|
||||
# now the --username option is only a fallback if both id and whoami
|
||||
# fail, and in that case the argument _must_ be the name of the effective
|
||||
# user.
|
||||
POSTGRES_SUPERUSERNAME=$EffectiveUser
|
||||
|
||||
# Note: The sysid can be freely selected. This will probably confuse matters,
|
||||
# but if your Unix user postgres is uid 48327 you might chose to start
|
||||
# at 0 (or 1) in the database.
|
||||
POSTGRES_SUPERUSERID=$EUID
|
||||
|
||||
Password='_null_'
|
||||
|
||||
while [ $# -gt 0 ]
|
||||
do
|
||||
case "$1" in
|
||||
--help|-\?)
|
||||
usage=t
|
||||
break
|
||||
;;
|
||||
--debug|-d)
|
||||
debug=1
|
||||
echo "Running with debug mode on."
|
||||
;;
|
||||
--noclean|-n)
|
||||
noclean=1
|
||||
echo "Running with noclean mode on. Mistakes will not be cleaned up."
|
||||
;;
|
||||
--template|-t)
|
||||
template_only=1
|
||||
echo "Updating template1 database only."
|
||||
;;
|
||||
# The database superuser. See comments above.
|
||||
--username|-u)
|
||||
POSTGRES_SUPERUSERNAME="$2"
|
||||
shift;;
|
||||
--username=*)
|
||||
POSTGRES_SUPERUSERNAME=`echo $1 | sed 's/^--username=//'`
|
||||
;;
|
||||
-u*)
|
||||
POSTGRES_SUPERUSERNAME=`echo $1 | sed 's/^-u//'`
|
||||
;;
|
||||
# The sysid of the database superuser. See comments above.
|
||||
--sysid|-i)
|
||||
POSTGRES_SUPERUSERID="$2"
|
||||
shift;;
|
||||
--sysid=*)
|
||||
POSTGRES_SUPERUSERID=`echo $1 | sed 's/^--sysid=//'`
|
||||
;;
|
||||
-i*)
|
||||
POSTGRES_SUPERUSERID=`echo $1 | sed 's/^-i//'`
|
||||
;;
|
||||
# The default password of the database superuser.
|
||||
--password|-W)
|
||||
Password="$2"
|
||||
shift;;
|
||||
--password=*)
|
||||
Password=`echo $1 | sed 's/^--password=//'`
|
||||
;;
|
||||
-W*)
|
||||
Password=`echo $1 | sed 's/^-W//'`
|
||||
;;
|
||||
# Directory where to install the data. No default, unless the environment
|
||||
# variable PGDATA is set.
|
||||
--pgdata|-D)
|
||||
PGDATA="$2"
|
||||
shift;;
|
||||
--pgdata=*)
|
||||
PGDATA=`echo $1 | sed 's/^--pgdata=//'`
|
||||
;;
|
||||
-D*)
|
||||
PGDATA=`echo $1 | sed 's/^-D//'`
|
||||
;;
|
||||
# The directory where the database templates are stored (traditionally in
|
||||
# $prefix/lib). This is now autodetected for the most common layouts.
|
||||
--pglib|-L)
|
||||
PGLIB="$2"
|
||||
shift;;
|
||||
--pglib=*)
|
||||
PGLIB=`echo $1 | sed 's/^--pglib=//'`
|
||||
;;
|
||||
-L*)
|
||||
PGLIB=`echo $1 | sed 's/^-L//'`
|
||||
;;
|
||||
# The encoding of the template1 database. Defaults to what you chose
|
||||
# at configure time. (see above)
|
||||
--pgencoding|-e)
|
||||
MULTIBYTE="$2"
|
||||
shift;;
|
||||
--pgencoding=*)
|
||||
MULTIBYTE=`echo $1 | sed 's/^--pgencoding=//'`
|
||||
;;
|
||||
-e*)
|
||||
MULTIBYTE=`echo $1 | sed 's/^-e//'`
|
||||
;;
|
||||
*)
|
||||
echo "Unrecognized option '$1'. Try -? for help."
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
|
||||
if [ "$usage" ]; then
|
||||
echo "$CMDNAME [-t|--template] [-d|--debug] [-n|--noclean] \\"
|
||||
echo " [-u|--username SUPERUSER] [-D|--pgdata DATADIR] \\"
|
||||
echo " [-L|--pglib=LIBDIR] [-e|--pgencoding=ENCODING]"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Resolve the multibyte encoding name
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
if [ "$MULTIBYTE" ]; then
|
||||
MULTIBYTEID=`$PGPATH/pg_encoding $MULTIBYTE`
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "The program pg_encoding failed. Perhaps you did not configure"
|
||||
echo "PostgreSQL for multibyte support or the program was not success-"
|
||||
echo "fully installed."
|
||||
exit 1
|
||||
fi
|
||||
if [ -z "$MULTIBYTEID" ]; then
|
||||
echo "$CMDNAME: $MULTIBYTE is not a valid encoding name."
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Make sure he told us where to build the database system
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
if [ -z "$PGDATA" ]; then
|
||||
echo "$CMDNAME: You must identify where the the data for this database"
|
||||
echo "system will reside. Do this with either a --pgdata invocation"
|
||||
echo "option or a PGDATA environment variable."
|
||||
echo
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# The data path must be absolute, because the backend doesn't like
|
||||
# '.' and '..' stuff. (Should perhaps be fixed there.)
|
||||
|
||||
if ! echo $PGDATA | grep -s '^/' >& /dev/null ; then
|
||||
echo "$CMDNAME: The data path must be specified as an absolute path."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
#---------------------------------------------------------------------------
|
||||
# Figure out who the Postgres superuser for the new database system will be.
|
||||
#---------------------------------------------------------------------------
|
||||
|
||||
# This means they have neither 'id' nor 'whoami'!
|
||||
if [ -z "$POSTGRES_SUPERUSERNAME" ]; then
|
||||
echo "$CMDNAME: Could not determine what the name of the database"
|
||||
echo "superuser should be. Please use the --username option."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "This database system will be initialized with username \"$POSTGRES_SUPERUSERNAME\"."
|
||||
echo "This user will own all the data files and must also own the server process."
|
||||
echo
|
||||
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
# Find the input files
|
||||
#-------------------------------------------------------------------------
|
||||
|
||||
if [ -z "$PGLIB" ]; then
|
||||
for dir in "$PGPATH/../lib" "$PGPATH/../lib/pgsql"; do
|
||||
if [ -f "$dir/global1.bki.source" ]; then
|
||||
PGLIB=$dir
|
||||
break
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
if [ -z "$PGLIB" ]; then
|
||||
echo "$CMDNAME: Could not find the \"lib\" directory, that contains"
|
||||
echo "the files needed by initdb. Please specify it with the"
|
||||
echo "--pglib option."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
|
||||
TEMPLATE=$PGLIB/local1_template1.bki.source
|
||||
GLOBAL=$PGLIB/global1.bki.source
|
||||
PG_HBA_SAMPLE=$PGLIB/pg_hba.conf.sample
|
||||
|
||||
TEMPLATE_DESCR=$PGLIB/local1_template1.description
|
||||
GLOBAL_DESCR=$PGLIB/global1.description
|
||||
PG_GEQO_SAMPLE=$PGLIB/pg_geqo.sample
|
||||
|
||||
for PREREQ_FILE in $TEMPLATE $GLOBAL $PG_HBA_SAMPLE; do
|
||||
if [ ! -f $PREREQ_FILE ]; then
|
||||
echo "$CMDNAME does not find the file '$PREREQ_FILE'."
|
||||
echo "This means you have a corrupted installation or identified the"
|
||||
echo "wrong directory with the --pglib invocation option."
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
|
||||
[ "$debug" -ne 0 ] && echo "$CMDNAME: Using $TEMPLATE as input to create the template database."
|
||||
|
||||
if [ $template_only -eq 0 ]; then
|
||||
[ "$debug" -ne 0 ] && echo "$CMDNAME: Using $GLOBAL as input to create the global classes."
|
||||
[ "$debug" -ne 0 ] && echo "$CMDNAME: Using $PG_HBA_SAMPLE as default authentication control file."
|
||||
fi
|
||||
|
||||
trap 'echo "Caught signal." ; exit_nicely' SIGINT SIGTERM
|
||||
|
||||
|
||||
# -----------------------------------------------------------------------
|
||||
# Create the data directory if necessary
|
||||
# -----------------------------------------------------------------------
|
||||
|
|
Loading…
Reference in a new issue