diff options
author | Bruce Momjian <bruce@momjian.us> | 1999-12-17 01:05:31 +0000 |
---|---|---|
committer | Bruce Momjian <bruce@momjian.us> | 1999-12-17 01:05:31 +0000 |
commit | 83bad7c063b6a800db9640d6cb14ef62b9027298 (patch) | |
tree | ef33d28074ba1d7581bfc679e369fe80f8101aa7 /src | |
parent | 1b22a8cb033b11721d22b5d5a6c550c571731dae (diff) | |
download | postgresql-83bad7c063b6a800db9640d6cb14ef62b9027298.tar.gz postgresql-83bad7c063b6a800db9640d6cb14ef62b9027298.zip |
This is my -- hopefully sufficiently portable -- attempt at cleaning out
initdb. No more obscure dependencies on environment variables or paths.
It
now finds the templates and the right postgres itself (with cmd line
options as fallback). It also no longer depends on $USER (su safe), and
doesn't advertise that --username allows you to install the db as a
different user, since that doesn't work anyway. Also, recovery and
cleanup
on all errors. Consistent options, clearer documentation.
Please take a look at this and adopt it if you feel it's safe enough. I
have simulated all the stupid circumstances I could think of, but you
never know with shell scripts.
Oh yeah, you can give the postgres user a default password now.
--
Peter Eisentraut Sernanders väg 10:115
Diffstat (limited to 'src')
-rw-r--r-- | src/bin/initdb/initdb.sh | 319 | ||||
-rw-r--r-- | src/include/catalog/pg_shadow.h | 38 |
2 files changed, 146 insertions, 211 deletions
diff --git a/src/bin/initdb/initdb.sh b/src/bin/initdb/initdb.sh index 4ccd718fc73..245f3455f94 100644 --- a/src/bin/initdb/initdb.sh +++ b/src/bin/initdb/initdb.sh @@ -26,7 +26,7 @@ # # # IDENTIFICATION -# $Header: /cvsroot/pgsql/src/bin/initdb/Attic/initdb.sh,v 1.65 1999/12/16 20:09:56 momjian Exp $ +# $Header: /cvsroot/pgsql/src/bin/initdb/Attic/initdb.sh,v 1.66 1999/12/17 01:05:30 momjian Exp $ # #------------------------------------------------------------------------- @@ -291,38 +291,31 @@ umask 077 if [ -f "$PGDATA/PG_VERSION" ]; then if [ $template_only -eq 0 ]; then - echo "$CMDNAME: error: File $PGDATA/PG_VERSION already exists." - echo "This probably means initdb has already been run and the " + echo "$CMDNAME: The file $PGDATA/PG_VERSION already exists." + echo "This probably means initdb has already been run and the" echo "database system already exists." echo - echo "If you want to create a new database system, either remove " - echo "the directory $PGDATA or run initdb with a --pgdata option " + echo "If you want to create a new database system, either remove" + echo "the directory $PGDATA or run initdb with a --pgdata argument" echo "other than $PGDATA." exit 1 fi else if [ ! -d $PGDATA ]; then - echo "Creating Postgres database system directory $PGDATA" - echo - mkdir $PGDATA - if [ $? -ne 0 ]; then exit 5; fi - else - echo "Fixing permissions on pre-existing $PGDATA" - echo - chmod go-rwx $PGDATA - if [ $? -ne 0 ]; then exit 5; fi + echo "Creating database system directory $PGDATA" + mkdir $PGDATA || exit_nicely + else + echo "Fixing permissions on pre-existing data directory $PGDATA" + chmod go-rwx $PGDATA || exit_nicely fi + if [ ! -d $PGDATA/base ]; then - echo "Creating Postgres database system directory $PGDATA/base" - echo - mkdir $PGDATA/base - if [ $? -ne 0 ]; then exit 5; fi + echo "Creating database system directory $PGDATA/base" + mkdir $PGDATA/base || exit_nicely fi if [ ! -d $PGDATA/pg_xlog ]; then - echo "Creating Postgres database XLOG directory $PGDATA/pg_xlog" - echo - mkdir $PGDATA/pg_xlog - if [ $? -ne 0 ]; then exit 5; fi + echo "Creating database XLOG directory $PGDATA/pg_xlog" + mkdir $PGDATA/pg_xlog || exit_nicely fi fi @@ -330,8 +323,8 @@ fi # Create the template1 database #---------------------------------------------------------------------------- -rm -rf $PGDATA/base/template1 -mkdir $PGDATA/base/template1 +rm -rf $PGDATA/base/template1 || exit_nicely +mkdir $PGDATA/base/template1 || exit_nicely if [ "$debug" -eq 1 ]; then BACKEND_TALK_ARG="-d" @@ -343,82 +336,51 @@ BACKENDARGS="-boot -C -F -D$PGDATA $BACKEND_TALK_ARG" FIRSTRUN="-boot -x -C -F -D$PGDATA $BACKEND_TALK_ARG" echo "Creating template database in $PGDATA/base/template1" -[ "$debug" -ne 0 ] && echo "Running: postgres $BACKENDARGS template1" +[ "$debug" -ne 0 ] && echo "Running: $PGPATH/postgres $FIRSTRUN template1" cat $TEMPLATE \ -| sed -e "s/postgres PGUID/$POSTGRES_SUPERUSERNAME $POSTGRES_SUPERUID/" \ - -e "s/PGUID/$POSTGRES_SUPERUID/" \ -| postgres $FIRSTRUN template1 +| sed -e "s/PGUID/$POSTGRES_SUPERUSERID/g" \ +| $PGPATH/postgres $FIRSTRUN template1 \ +|| exit_nicely -if [ $? -ne 0 ]; then - echo "$CMDNAME: could not create template database" - if [ $noclean -eq 0 ]; then - echo "$CMDNAME: cleaning up by wiping out $PGDATA/base/template1" - rm -rf $PGDATA/base/template1 - else - echo "$CMDNAME: cleanup not done because noclean options was used." - fi - exit 1; -fi - -echo - -pg_version $PGDATA/base/template1 +$PGPATH/pg_version $PGDATA/base/template1 || exit_nicely #---------------------------------------------------------------------------- # Create the global classes, if requested. #---------------------------------------------------------------------------- if [ $template_only -eq 0 ]; then - echo "Creating global classes in $PGDATA/base" - [ "$debug" -ne 0 ] && echo "Running: postgres $BACKENDARGS template1" + echo "Creating global relations in $PGDATA/base" + [ "$debug" -ne 0 ] && echo "Running: $PGPATH/postgres $BACKENDARGS template1" cat $GLOBAL \ - | sed -e "s/postgres PGUID/$POSTGRES_SUPERUSERNAME $POSTGRES_SUPERUID/" \ - -e "s/PGUID/$POSTGRES_SUPERUID/" \ - | postgres $BACKENDARGS template1 - - if (test $? -ne 0) - then - echo "$CMDNAME: could not create global classes." - if (test $noclean -eq 0); then - echo "$CMDNAME: cleaning up." - rm -rf $PGDATA - else - echo "$CMDNAME: cleanup not done (noclean mode set)." - fi - exit 1; - fi + | sed -e "s/POSTGRES/$POSTGRES_SUPERUSERNAME/g" \ + -e "s/PGUID/$POSTGRES_SUPERUSERID/g" \ + -e "s/PASSWORD/$Password/g" \ + | $PGPATH/postgres $BACKENDARGS template1 \ + || exit_nicely - echo - - pg_version $PGDATA - - cp $PG_HBA_SAMPLE $PGDATA/pg_hba.conf - cp $PG_GEQO_SAMPLE $PGDATA/pg_geqo.sample + $PGPATH/pg_version $PGDATA || exit_nicely - echo "Adding template1 database to pg_database..." + cp $PG_HBA_SAMPLE $PGDATA/pg_hba.conf || exit_nicely + cp $PG_GEQO_SAMPLE $PGDATA/pg_geqo.sample || exit_nicely - echo "open pg_database" > /tmp/create.$$ - echo "insert (template1 $POSTGRES_SUPERUID $MULTIBYTEID template1)" >> /tmp/create.$$ - #echo "show" >> /tmp/create.$$ - echo "close pg_database" >> /tmp/create.$$ + echo "Adding template1 database to pg_database" - [ "$debug" -ne 0 ] && echo "Running: postgres $BACKENDARGS template1 < /tmp/create.$$" + echo "open pg_database" > $TEMPFILE + echo "insert (template1 $POSTGRES_SUPERUSERID $MULTIBYTEID template1)" >> $TEMPFILE + #echo "show" >> $TEMPFILE + echo "close pg_database" >> $TEMPFILE - postgres $BACKENDARGS template1 < /tmp/create.$$ + [ "$debug" -ne 0 ] && echo "Running: $PGPATH/postgres $BACKENDARGS template1 < $TEMPFILE" - if [ $? -ne 0 ]; then - echo "$CMDNAME: could not log template database" - if [ $noclean -eq 0 ]; then - echo "$CMDNAME: cleaning up." - rm -rf $PGDATA - else - echo "$CMDNAME: cleanup not done (noclean mode set)." - fi - exit 1; + $PGPATH/postgres $BACKENDARGS template1 < $TEMPFILE + # Gotta remove that temp file before exiting on error. + retval=$? + if [ $noclean -eq 0 ]; then + rm -f $TEMPFILE || exit_nicely fi - rm -f /tmp/create.$$ + [ $retval -ne 0 ] && exit_nicely fi echo @@ -427,102 +389,103 @@ PGSQL_OPT="-o /dev/null -O -F -Q -D$PGDATA" # Create a trigger so that direct updates to pg_shadow will be written # to the flat password file pg_pwd -echo "CREATE TRIGGER pg_sync_pg_pwd AFTER INSERT OR UPDATE OR DELETE ON pg_shadow FOR EACH ROW EXECUTE PROCEDURE update_pg_pwd()" | postgres $PGSQL_OPT template1 > /dev/null +echo "CREATE TRIGGER pg_sync_pg_pwd AFTER INSERT OR UPDATE OR DELETE ON pg_shadow" \ + "FOR EACH ROW EXECUTE PROCEDURE update_pg_pwd()" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely # Create the initial pg_pwd (flat-file copy of pg_shadow) -echo "COPY pg_shadow TO '$PGDATA/pg_pwd' USING DELIMITERS '\\t'" | \ - postgres $PGSQL_OPT template1 > /dev/null +echo "Writing password file." +echo "COPY pg_shadow TO '$PGDATA/pg_pwd' USING DELIMITERS '\\t'" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + # An ordinary COPY will leave the file too loosely protected. -chmod go-rw $PGDATA/pg_pwd - -echo "Creating public pg_user view" -echo "CREATE TABLE pg_user ( \ - usename name, \ - usesysid int4, \ - usecreatedb bool, \ - usetrace bool, \ - usesuper bool, \ - usecatupd bool, \ - passwd text, \ - valuntil abstime);" | postgres $PGSQL_OPT template1 > /dev/null - - -echo "CREATE RULE \"_RETpg_user\" AS ON SELECT TO pg_user DO INSTEAD \ - SELECT usename, usesysid, usecreatedb, usetrace, \ - usesuper, usecatupd, '********'::text as passwd, \ - valuntil FROM pg_shadow;" | \ - postgres $PGSQL_OPT template1 > /dev/null -echo "REVOKE ALL on pg_shadow FROM public" | \ - postgres $PGSQL_OPT template1 > /dev/null - -echo "Creating view pg_rules" -echo "CREATE TABLE pg_rules ( \ - tablename name, \ - rulename name, \ - definition text);" | postgres $PGSQL_OPT template1 > /dev/null - -echo "CREATE RULE \"_RETpg_rules\" AS ON SELECT TO pg_rules DO INSTEAD \ - SELECT C.relname AS tablename, \ - R.rulename AS rulename, \ - pg_get_ruledef(R.rulename) AS definition \ - FROM pg_rewrite R, pg_class C \ - WHERE R.rulename !~ '^_RET' \ - AND C.oid = R.ev_class;" | \ - postgres $PGSQL_OPT template1 > /dev/null - -echo "Creating view pg_views" -echo "CREATE TABLE pg_views ( \ - viewname name, \ - viewowner name, \ - definition text);" | postgres $PGSQL_OPT template1 > /dev/null - -echo "CREATE RULE \"_RETpg_views\" AS ON SELECT TO pg_views DO INSTEAD \ - SELECT C.relname AS viewname, \ - pg_get_userbyid(C.relowner) AS viewowner, \ - pg_get_viewdef(C.relname) AS definition \ - FROM pg_class C WHERE C.relhasrules AND \ - EXISTS (SELECT rulename FROM pg_rewrite R \ - WHERE ev_class = C.oid AND ev_type = '1');" | \ - postgres $PGSQL_OPT template1 > /dev/null - -echo "Creating view pg_tables" -echo "CREATE TABLE pg_tables ( \ - tablename name, \ - tableowner name, \ - hasindexes bool, \ - hasrules bool, \ - hastriggers bool);" | postgres $PGSQL_OPT template1 > /dev/null - -echo "CREATE RULE \"_RETpg_tables\" AS ON SELECT TO pg_tables DO INSTEAD \ - SELECT C.relname AS tablename, \ - pg_get_userbyid(C.relowner) AS tableowner, \ - C.relhasindex AS hasindexes, \ - C.relhasrules AS hasrules, \ - (C.reltriggers > 0) AS hastriggers \ - FROM pg_class C WHERE C.relkind IN ('r', 's') \ - AND NOT EXISTS (SELECT rulename FROM pg_rewrite \ - WHERE ev_class = C.oid AND ev_type = '1');" | \ - postgres $PGSQL_OPT template1 > /dev/null - -echo "Creating view pg_indexes" -echo "CREATE TABLE pg_indexes ( \ - tablename name, \ - indexname name, \ - indexdef text);" | postgres $PGSQL_OPT template1 > /dev/null - -echo "CREATE RULE \"_RETpg_indexes\" AS ON SELECT TO pg_indexes DO INSTEAD \ - SELECT C.relname AS tablename, \ - I.relname AS indexname, \ - pg_get_indexdef(X.indexrelid) AS indexdef \ - FROM pg_index X, pg_class C, pg_class I \ - WHERE C.oid = X.indrelid \ - AND I.oid = X.indexrelid;" | \ - postgres $PGSQL_OPT template1 > /dev/null - -echo "Loading pg_description" -echo "copy pg_description from '$TEMPLATE_DESCR'" | \ - postgres $PGSQL_OPT template1 > /dev/null -echo "copy pg_description from '$GLOBAL_DESCR'" | \ - postgres $PGSQL_OPT template1 > /dev/null -echo "vacuum analyze" | \ - postgres $PGSQL_OPT template1 > /dev/null +# Note: If you lied above and specified a --username different from the one +# you really are, this will manifest itself in this command failing because +# of a missing file, since the COPY command above failed. It would perhaps +# be better if postgres returned an error code. +chmod go-rw $PGDATA/pg_pwd || exit_nicely + +echo "Creating view pg_user." +echo "CREATE VIEW pg_user AS + SELECT + usename, + usesysid, + usecreatedb, + usetrace, + usesuper, + usecatupd, + '********'::text as passwd, + valuntil + FROM pg_shadow" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo "REVOKE ALL on pg_shadow FROM public" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo "Creating view pg_rules." +echo "CREATE VIEW pg_rules AS + SELECT + C.relname AS tablename, + R.rulename AS rulename, + pg_get_ruledef(R.rulename) AS definition + FROM pg_rewrite R, pg_class C + WHERE R.rulename !~ '^_RET' + AND C.oid = R.ev_class;" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo "Creating view pg_views." +echo "CREATE VIEW pg_views AS + SELECT + C.relname AS viewname, + pg_get_userbyid(C.relowner) AS viewowner, + pg_get_viewdef(C.relname) AS definition + FROM pg_class C + WHERE C.relhasrules + AND EXISTS ( + SELECT rulename FROM pg_rewrite R + WHERE ev_class = C.oid AND ev_type = '1' + )" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo "Creating view pg_tables." +echo "CREATE VIEW pg_tables AS + SELECT + C.relname AS tablename, + pg_get_userbyid(C.relowner) AS tableowner, + C.relhasindex AS hasindexes, + C.relhasrules AS hasrules, + (C.reltriggers > 0) AS hastriggers + FROM pg_class C + WHERE C.relkind IN ('r', 's') + AND NOT EXISTS ( + SELECT rulename FROM pg_rewrite + WHERE ev_class = C.oid AND ev_type = '1' + )" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo "Creating view pg_indexes." +echo "CREATE VIEW pg_indexes AS + SELECT + C.relname AS tablename, + I.relname AS indexname, + pg_get_indexdef(X.indexrelid) AS indexdef + FROM pg_index X, pg_class C, pg_class I + WHERE C.oid = X.indrelid + AND I.oid = X.indexrelid" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo "Loading pg_description." +echo "COPY pg_description FROM '$TEMPLATE_DESCR'" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely +echo "COPY pg_description FROM '$GLOBAL_DESCR'" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely +echo "Vacuuming database." +echo "VACUUM ANALYZE" \ + | $PGPATH/postgres $PGSQL_OPT template1 > /dev/null || exit_nicely + +echo +echo "$CMDNAME completed successfully. You can now start the database server." +echo "($PGPATH/postmaster -D $PGDATA)" +echo + +exit 0 diff --git a/src/include/catalog/pg_shadow.h b/src/include/catalog/pg_shadow.h index 1a54a92070f..781caca899b 100644 --- a/src/include/catalog/pg_shadow.h +++ b/src/include/catalog/pg_shadow.h @@ -8,7 +8,7 @@ * * Copyright (c) 1994, Regents of the University of California * - * $Id: pg_shadow.h,v 1.4 1999/02/13 23:21:14 momjian Exp $ + * $Id: pg_shadow.h,v 1.5 1999/12/17 01:05:31 momjian Exp $ * * NOTES * the genbki.sh script reads this file and generates .bki @@ -67,39 +67,11 @@ typedef FormData_pg_shadow *Form_pg_shadow; /* ---------------- * initial contents of pg_shadow + * + * The uppercase quantities will be replaced at initdb time with + * user choices. * ---------------- */ -DATA(insert OID = 0 ( postgres PGUID t t t t _null_ 2116994400 )); - -BKI_BEGIN -#ifdef ALLOW_PG_GROUP -BKI_END - -DATA(insert OID = 0 ( mike 799 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( mao 1806 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( hellers 1089 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( joey 5209 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( jolly 5443 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( sunita 6559 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( paxson 3029 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( marc 2435 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( jiangwu 6124 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( aoki 2360 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( avi 31080 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( kristin 1123 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( andrew 5229 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( nobuko 5493 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( hartzell 6676 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( devine 6724 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( boris 6396 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( sklower 354 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( marcel 31113 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( ginger 3692 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( woodruff 31026 t t t t _null_ 2116994400 )); -DATA(insert OID = 0 ( searcher 8261 t t t t _null_ 2116994400 )); - -BKI_BEGIN -#endif /* ALLOW_PG_GROUP */ -BKI_END +DATA(insert OID = 0 ( POSTGRES PGUID t t t t PASSWORD _null_ )); #endif /* PG_SHADOW_H */ |