mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-18 18:44:06 +08:00
Update permissions?
This commit is contained in:
parent
2004337785
commit
ebf57dd082
@ -12,21 +12,21 @@ SSYYNNOOPPSSIISS
|
|||||||
data
|
data
|
||||||
|
|
||||||
DDEESSCCRRIIPPTTIIOONN
|
DDEESSCCRRIIPPTTIIOONN
|
||||||
pg_upgrade is a utility for upgrading from a previous
|
ppgg__uuppggrraaddee is a utility for upgrading from a previous
|
||||||
PostgreSQL release without reloading all the data. Not all
|
PostgreSQL release without reloading all the data. Not all
|
||||||
PostgreSQL releases can be handled this way. Check the
|
PostgreSQL releases can use this utility. Check the
|
||||||
release notes for details about your version.
|
release notes for details about your version.
|
||||||
|
|
||||||
pg_upgrade must be run in two stages. In phase one you
|
ppgg__uuppggrraaddee must be run in two stages. In phase one you
|
||||||
must run pg_upgrade with your old database installation in
|
must run ppgg__uuppggrraaddee with your old database installation in
|
||||||
place. In phase two, pg_upgrade must be run on a freshly
|
place. In phase two, ppgg__uuppggrraaddee must be run on a freshly
|
||||||
initdb'ed current install. In both phases, the same
|
iinniittddbb'ed current install. In both phases, the same
|
||||||
pg_upgrade script matching the newly installed version
|
ppgg__uuppggrraaddee script matching the newly installed version
|
||||||
must be used.
|
must be used.
|
||||||
|
|
||||||
UUppggrraaddiinngg PPoossttggrreeSSQQLL wwiitthh ppgg__uuppggrraaddee
|
UUppggrraaddiinngg PPoossttggrreeSSQQLL wwiitthh ppgg__uuppggrraaddee
|
||||||
1) Back up your existing data directory, preferably by
|
1) Back up your existing data directory, preferably by
|
||||||
making a complete dump with pg_dumpall.
|
making a complete dump with ppgg__dduummppaallll..
|
||||||
|
|
||||||
2) Copy the program _p_g_s_q_l_/_c_o_n_t_r_i_b_/_p_g___u_p_g_r_a_d_e_/_p_g___u_p_g_r_a_d_e
|
2) Copy the program _p_g_s_q_l_/_c_o_n_t_r_i_b_/_p_g___u_p_g_r_a_d_e_/_p_g___u_p_g_r_a_d_e
|
||||||
from the current PostgreSQL distribution somewhere into
|
from the current PostgreSQL distribution somewhere into
|
||||||
@ -52,7 +52,7 @@ UUppggrraaddiinngg PPoossttggrreeSSQQLL wwiitthh ppgg_
|
|||||||
$$ mmaakkee iinnssttaallll
|
$$ mmaakkee iinnssttaallll
|
||||||
|
|
||||||
to install the _p_g___r_e_s_e_t_x_l_o_g utility which is needed by
|
to install the _p_g___r_e_s_e_t_x_l_o_g utility which is needed by
|
||||||
pg_upgrade.
|
ppgg__uuppggrraaddee.
|
||||||
|
|
||||||
6) Run initdb to create a new template1 database contain-
|
6) Run initdb to create a new template1 database contain-
|
||||||
ing the system tables for the new release. Make sure you
|
ing the system tables for the new release. Make sure you
|
||||||
@ -76,7 +76,7 @@ PG_UPGRADE(1) PostgreSQL Client Applications PG_UPGRADE(1)
|
|||||||
alter pg_hba.conf temporarily.)
|
alter pg_hba.conf temporarily.)
|
||||||
|
|
||||||
8) Change your working directory to the pgsql main direc-
|
8) Change your working directory to the pgsql main direc-
|
||||||
tory, and type:
|
tory again, and type:
|
||||||
|
|
||||||
$$ ppgg__uuppggrraaddee --22
|
$$ ppgg__uuppggrraaddee --22
|
||||||
|
|
||||||
@ -92,12 +92,13 @@ PG_UPGRADE(1) PostgreSQL Client Applications PG_UPGRADE(1)
|
|||||||
|
|
||||||
10) Carefully examine the contents of the upgraded
|
10) Carefully examine the contents of the upgraded
|
||||||
databases. If you detect problems, you'll need to recover
|
databases. If you detect problems, you'll need to recover
|
||||||
by restoring from your full pg_dump backup. You can delete
|
by restoring from your full ppgg__dduummppaallll backup. You can
|
||||||
the _p_g___u_p_g_r_a_d_e___i_n_f_o_/ directory when you are satisfied.
|
delete the _p_g___u_p_g_r_a_d_e___i_n_f_o_/ directory when you are satis-
|
||||||
|
fied.
|
||||||
|
|
||||||
The upgraded databases will be in an un-vacuumed state.
|
The upgraded databases will be in an un-vacuumed state.
|
||||||
You will probably want to run a _V_A_C_U_U_M _A_N_A_L_Y_Z_E bbeeffoorree
|
You will probably want to run a _V_A_C_U_U_M _A_N_A_L_Y_Z_E before
|
||||||
bbeeggiinnnniinngg pprroodduuccttiioonn wwoorrkk..
|
beginning production work.
|
||||||
|
|
||||||
SSEEEE AALLSSOO
|
SSEEEE AALLSSOO
|
||||||
initdb(1), postmaster(1), pg_dump(1), pg_dumpall(1), vacu-
|
initdb(1), postmaster(1), pg_dump(1), pg_dumpall(1), vacu-
|
||||||
@ -124,7 +125,6 @@ SSEEEE AALLSSOO
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
14 Jan 2002 PG_UPGRADE(1) 2
|
14 Jan 2002 PG_UPGRADE(1) 2
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
# pg_upgrade: update a database without needing a full dump/reload cycle.
|
# pg_upgrade: update a database without needing a full dump/reload cycle.
|
||||||
# CAUTION: Read the manual page before trying to use this!
|
# CAUTION: Read the manual page before trying to use this!
|
||||||
|
|
||||||
# $Header: /cvsroot/pgsql/contrib/pg_upgrade/Attic/pg_upgrade,v 1.1 2002/01/14 17:32:07 momjian Exp $
|
# $Header: /cvsroot/pgsql/contrib/pg_upgrade/Attic/pg_upgrade,v 1.2 2002/01/14 22:54:44 momjian Exp $
|
||||||
#
|
#
|
||||||
# NOTE: we must be sure to update the version-checking code a few dozen lines
|
# NOTE: we must be sure to update the version-checking code a few dozen lines
|
||||||
# below for each new PostgreSQL release.
|
# below for each new PostgreSQL release.
|
||||||
@ -30,6 +30,7 @@ CUR_VERSION="7.2"
|
|||||||
trap "rm -f /tmp/$$.*" 0 1 2 3 15
|
trap "rm -f /tmp/$$.*" 0 1 2 3 15
|
||||||
|
|
||||||
PHASE=""
|
PHASE=""
|
||||||
|
|
||||||
if [ "$#" -eq 1 ]
|
if [ "$#" -eq 1 ]
|
||||||
then
|
then
|
||||||
if [ "X$1" = "X-1" ]
|
if [ "X$1" = "X-1" ]
|
||||||
@ -38,26 +39,41 @@ then
|
|||||||
elif [ "X$1" = "X-2" ]
|
elif [ "X$1" = "X-2" ]
|
||||||
then PHASE="2"
|
then PHASE="2"
|
||||||
shift
|
shift
|
||||||
|
elif [ "X$1" = "X-D" ]
|
||||||
|
then DATADIR="$2"
|
||||||
|
shift
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$PHASE" = "" ]
|
if [ "$PHASE" = "" ]
|
||||||
then echo "You must run $0 in either mode 1 or mode 2." 1>&2
|
then echo "You must run $0 in either mode 1 or mode 2." 1>&2
|
||||||
echo "Usage: $0 [ -1 | -2 ]" 1>&2
|
echo "Usage: $0 [-D datadir] -1 | -2" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -e data ]
|
if [ "$DATADIR" = "" ]
|
||||||
then echo "$0 must be run from the directory above your /data directory.
|
then echo "You must set the DATADIR environment variable or specify it with -D." 1>&2
|
||||||
|
echo "Usage: $0 [-D datadir] -1 | -2" 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "$DATADIR" ]
|
||||||
|
then echo "$DATADIR does not exist.
|
||||||
$0 aborted." 1>&2
|
$0 aborted." 1>&2
|
||||||
if [ "$PHASE" -eq 2 ]
|
if [ "$PHASE" -eq 2 ]
|
||||||
then echo "You must run initdb to create a template1 database." 1>&2
|
then echo "Perhaps you didn't run initdb." 1>&2
|
||||||
fi
|
fi
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ "$USER" = "root" -o ! -r "$DATADIR"/PG_VERSION ]
|
||||||
|
then echo "You must run this as the PostgreSQL superuser.
|
||||||
|
$0 aborted." 1>&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
INFODIR="pg_upgrade_info"
|
INFODIR="pg_upgrade_info"
|
||||||
OLDDIR="$INFODIR/data"
|
SAVEDATA="$INFODIR"/"`basename \"$DATADIR\"`"
|
||||||
|
|
||||||
make_dbobjoidmap()
|
make_dbobjoidmap()
|
||||||
{
|
{
|
||||||
@ -99,13 +115,15 @@ move_objfiles()
|
|||||||
{
|
{
|
||||||
# Test to make sure there is a matching file in each place
|
# Test to make sure there is a matching file in each place
|
||||||
|
|
||||||
if [ ! -e "$OLDDIR"/base/"$SRC_DBOID"/"$SRC_OID" ]
|
if [ ! -f "$SAVEDATA"/base/"$SRC_DBOID"/"$SRC_OID" -a \
|
||||||
|
! -h "$SAVEDATA"/base/"$SRC_DBOID"/"$SRC_OID" ]
|
||||||
then echo "Move of database $DB, OID $SRC_OID, object $OBJ failed.
|
then echo "Move of database $DB, OID $SRC_OID, object $OBJ failed.
|
||||||
File not found; exiting" 1>&2
|
File not found; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -e data/base/"$DST_DBOID"/"$DST_OID" ]
|
if [ ! -f "$DATADIR"/base/"$DST_DBOID"/"$DST_OID" -a \
|
||||||
|
! -h "$DATADIR"/base/"$DST_DBOID"/"$DST_OID" ]
|
||||||
then echo "Move of database $DB, OID $DST_OID, object $OBJ failed.
|
then echo "Move of database $DB, OID $DST_OID, object $OBJ failed.
|
||||||
File not found; exiting" 1>&2
|
File not found; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
@ -113,7 +131,7 @@ File not found; exiting" 1>&2
|
|||||||
|
|
||||||
# Move files
|
# Move files
|
||||||
|
|
||||||
mv -f "$OLDDIR"/base/"$SRC_DBOID"/"$SRC_OID" data/base/"$DST_DBOID"/"$DST_OID"
|
mv -f "$SAVEDATA"/base/"$SRC_DBOID"/"$SRC_OID" "$DATADIR"/base/"$DST_DBOID"/"$DST_OID"
|
||||||
if [ "$?" -ne 0 ]
|
if [ "$?" -ne 0 ]
|
||||||
then echo "Move of database $DB, OID $SRC_OID, object $OBJ
|
then echo "Move of database $DB, OID $SRC_OID, object $OBJ
|
||||||
to $DST_OID failed.; exiting" 1>&2
|
to $DST_OID failed.; exiting" 1>&2
|
||||||
@ -122,10 +140,10 @@ to $DST_OID failed.; exiting" 1>&2
|
|||||||
|
|
||||||
# handle table extents
|
# handle table extents
|
||||||
|
|
||||||
ls "$OLDDIR"/base/"$SRC_DBOID"/"$SRC_OID".* 2>/dev/null | while read FILE
|
ls "$SAVEDATA"/base/"$SRC_DBOID"/"$SRC_OID".* 2>/dev/null | while read FILE
|
||||||
do
|
do
|
||||||
EXT=`basename "$FILE" | sed 's/^.*\.\(.*\)$/\1/'`
|
EXT=`basename "$FILE" | sed 's/^.*\.\(.*\)$/\1/'`
|
||||||
mv -f "$FILE" data/base/"$DST_DBOID"/"$DST_OID"."$EXT"
|
mv -f "$FILE" "$DATADIR"/base/"$DST_DBOID"/"$DST_OID"."$EXT"
|
||||||
if [ "$?" -ne 0 ]
|
if [ "$?" -ne 0 ]
|
||||||
then echo "Move of database $DB, OID $SRC_OID, object $OBJ
|
then echo "Move of database $DB, OID $SRC_OID, object $OBJ
|
||||||
to $DST_OID failed.; exiting" 1>&2
|
to $DST_OID failed.; exiting" 1>&2
|
||||||
@ -142,15 +160,15 @@ then
|
|||||||
##########################
|
##########################
|
||||||
|
|
||||||
|
|
||||||
if [ ! -d data/base/1 ]
|
if [ ! -d "$DATADIR"/base/1 ]
|
||||||
then echo "There is no database template1 in data/base." 1>&2
|
then echo "There is no database template1 in $DATADIR/base." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# get version
|
# get version
|
||||||
SRC_VERSION="`cat data/PG_VERSION`"
|
SRC_VERSION=`cat "$DATADIR"/PG_VERSION`
|
||||||
if [ "$SRC_VERSION" = "" ]
|
if [ "$SRC_VERSION" = "" ]
|
||||||
then echo "$0 can not find PostgreSQL version file 'data/PG_VERSION'.
|
then echo "$0 can not find PostgreSQL version file '$DATADIR/PG_VERSION'.
|
||||||
$0 aborted." 1>&2
|
$0 aborted." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@ -258,9 +276,9 @@ $0 aborted." 1>&2
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mv data "$INFODIR"
|
mv "$DATADIR" "$INFODIR"
|
||||||
if [ $? -ne 0 ]
|
if [ $? -ne 0 ]
|
||||||
then echo "Can not move old /data out of the way.
|
then echo "Can not move old /$DATADIR out of the way.
|
||||||
$0 aborted." 1>&2
|
$0 aborted." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@ -283,38 +301,38 @@ then echo "There is no '$INFODIR' directory from a phase 1 run of $0." 1>&2
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -e "$OLDDIR" ]
|
if [ ! -d "$SAVEDATA" ]
|
||||||
then echo "There is no '$OLDDIR' directory from the phase 1 run of $0." 1>&2
|
then echo "There is no '$SAVEDATA' directory from the phase 1 run of $0." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f "$OLDDIR/PG_VERSION" ]
|
if [ ! -f "$SAVEDATA/PG_VERSION" ]
|
||||||
then echo "Cannot read '$OLDDIR/PG_VERSION' --- something is wrong." 1>&2
|
then echo "Cannot read '$SAVEDATA/PG_VERSION' --- something is wrong." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f "data/PG_VERSION" ]
|
if [ ! -f "$DATADIR/PG_VERSION" ]
|
||||||
then echo "Cannot read 'data/PG_VERSION' --- something is wrong." 1>&2
|
then echo "Cannot read '$DATADIR/PG_VERSION' --- something is wrong." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -d "data/base/1" ]
|
if [ ! -d "$DATADIR/base/1" ]
|
||||||
then echo "Cannot find database template1 in 'data/base'." 1>&2
|
then echo "Cannot find database template1 in '$DATADIR/base'." 1>&2
|
||||||
echo "Are you running $0 as the postgres superuser?" 1>&2
|
echo "Are you running $0 as the postgres superuser?" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Get the actual versions seen in the data dirs.
|
# Get the actual versions seen in the data dirs.
|
||||||
|
|
||||||
SRC_VERSION=`cat "$OLDDIR"/PG_VERSION`
|
SRC_VERSION=`cat "$SAVEDATA"/PG_VERSION`
|
||||||
DST_VERSION=`cat data/PG_VERSION`
|
DST_VERSION=`cat "$DATADIR"/PG_VERSION`
|
||||||
|
|
||||||
# Check for version compatibility.
|
# Check for version compatibility.
|
||||||
# This code will need to be updated/reviewed for each new PostgreSQL release.
|
# This code will need to be updated/reviewed for each new PostgreSQL release.
|
||||||
|
|
||||||
if [ "$DST_VERSION" != "$CUR_VERSION" ]
|
if [ "$DST_VERSION" != "$CUR_VERSION" ]
|
||||||
then echo "$0 is for PostgreSQL version $CUR_VERSION
|
then echo "$0 is for PostgreSQL version $CUR_VERSION
|
||||||
but data/PG_VERSION contains $DST_VERSION." 1>&2
|
but $DATADIR/PG_VERSION contains $DST_VERSION." 1>&2
|
||||||
echo "Did you run initdb for version $UPGRADE_VERSION by mistake?" 1>&2
|
echo "Did you run initdb for version $UPGRADE_VERSION by mistake?" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@ -349,17 +367,17 @@ fi
|
|||||||
# If the XID is > 2 billion, 7.1 database will have non-frozen XID's in
|
# If the XID is > 2 billion, 7.1 database will have non-frozen XID's in
|
||||||
# low numbers, and 7.2 will think they are in the future --- bad.
|
# low numbers, and 7.2 will think they are in the future --- bad.
|
||||||
|
|
||||||
SRC_XID=`pg_resetxlog -n "$OLDDIR" | grep "NextXID" | awk -F' *' '{print $4}'`
|
SRC_XID=`pg_resetxlog -n "$SAVEDATA" | grep "NextXID" | awk -F' *' '{print $4}'`
|
||||||
if [ "$SRC_VERSION" = "7.1" -a "$SRC_XID" -gt 2000000000 ]
|
if [ "$SRC_VERSION" = "7.1" -a "$SRC_XID" -gt 2000000000 ]
|
||||||
then echo "XID too high for $0.; exiting" 1>&2
|
then echo "XID too high for $0.; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
DST_XID=`pg_resetxlog -n data | grep "NextXID" | awk -F' *' '{print $4}'`
|
DST_XID=`pg_resetxlog -n "$DATADIR" | grep "NextXID" | awk -F' *' '{print $4}'`
|
||||||
|
|
||||||
# compare locales to make sure they match
|
# compare locales to make sure they match
|
||||||
|
|
||||||
pg_resetxlog -n "$OLDDIR" | grep "^LC_" > /tmp/$$.0
|
pg_resetxlog -n "$SAVEDATA" | grep "^LC_" > /tmp/$$.0
|
||||||
pg_resetxlog -n data | grep "^LC_" > /tmp/$$.1
|
pg_resetxlog -n "$DATADIR" | grep "^LC_" > /tmp/$$.1
|
||||||
if ! diff /tmp/$$.0 /tmp/$$.1 >/dev/null
|
if ! diff /tmp/$$.0 /tmp/$$.1 >/dev/null
|
||||||
then echo "Locales do not match between the two versions.; exiting" 1>&2
|
then echo "Locales do not match between the two versions.; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
@ -470,7 +488,7 @@ then MAX_XID="$SRC_XID"
|
|||||||
else MAX_XID="$DST_XID"
|
else MAX_XID="$DST_XID"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
pg_resetxlog -x "$MAX_XID" data
|
pg_resetxlog -x "$MAX_XID" "$DATADIR"
|
||||||
if [ "$?" -ne 0 ]
|
if [ "$?" -ne 0 ]
|
||||||
then echo "Unable to set new XID.; exiting" 1>&2
|
then echo "Unable to set new XID.; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
@ -478,18 +496,18 @@ fi
|
|||||||
|
|
||||||
# Move over old WAL
|
# Move over old WAL
|
||||||
|
|
||||||
rm -r data/pg_xlog
|
rm -r "$DATADIR"/pg_xlog
|
||||||
mv -f "$OLDDIR"/pg_xlog data
|
mv -f "$SAVEDATA"/pg_xlog "$DATADIR"
|
||||||
|
|
||||||
# Set last log file id and segment from old database
|
# Set last log file id and segment from old database
|
||||||
|
|
||||||
LOG_ID=`pg_resetxlog -n "$OLDDIR" | grep "Current log file id:" |
|
LOG_ID=`pg_resetxlog -n "$SAVEDATA" | grep "Current log file id:" |
|
||||||
awk -F' *' '{print $5}'`
|
awk -F' *' '{print $5}'`
|
||||||
if [ "$LOG_ID" = "" ]
|
if [ "$LOG_ID" = "" ]
|
||||||
then echo "Unable to get old log file id.; exiting" 1>&2
|
then echo "Unable to get old log file id.; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
SEG_ID=`pg_resetxlog -n "$OLDDIR" | grep "Next log file segment:" |
|
SEG_ID=`pg_resetxlog -n "$SAVEDATA" | grep "Next log file segment:" |
|
||||||
awk -F' *' '{print $5}'`
|
awk -F' *' '{print $5}'`
|
||||||
if [ "$SEG_ID" = "" ]
|
if [ "$SEG_ID" = "" ]
|
||||||
then echo "Unable to get old log segment id.; exiting" 1>&2
|
then echo "Unable to get old log segment id.; exiting" 1>&2
|
||||||
@ -498,7 +516,7 @@ fi
|
|||||||
|
|
||||||
# Set checkpoint location of new database
|
# Set checkpoint location of new database
|
||||||
|
|
||||||
pg_resetxlog -l "$LOG_ID" "$SEG_ID" data
|
pg_resetxlog -l "$LOG_ID" "$SEG_ID" "$DATADIR"
|
||||||
if [ "$?" -ne 0 ]
|
if [ "$?" -ne 0 ]
|
||||||
then echo "Unable to set new log file/segment id.; exiting" 1>&2
|
then echo "Unable to set new log file/segment id.; exiting" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -1,23 +1,23 @@
|
|||||||
.TH PG_UPGRADE 1 "PG_UPGRADE(1)" "14 Jan 2002" "PostgreSQL Client Applications" ""
|
.TH PG_UPGRADE 1 "PG_UPGRADE(1)" "14 Jan 2002" "PostgreSQL Client Applications" ""
|
||||||
.SH NAME
|
.SH NAME
|
||||||
pg_upgrade \- upgrade tool
|
pg_upgrade \- upgrading from a previous release without reloading
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
Allows upgrading from a previous release without reloading data
|
pg_upgrade [-D \fIdata_dir\fP] -1 | -2
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
pg_upgrade is a utility for upgrading from a previous PostgreSQL release
|
\fBpg_upgrade\fP is a utility for upgrading from a previous PostgreSQL release
|
||||||
without reloading all the data. Not all PostgreSQL releases can be
|
without reloading all the data. Not all PostgreSQL releases can use
|
||||||
handled this way. Check the release notes for details about your
|
this utility. Check the release notes for details about your
|
||||||
version.
|
version.
|
||||||
.LP
|
.LP
|
||||||
pg_upgrade must be run in two stages. In phase one you must run
|
\fBpg_upgrade\fP must be run in two stages. In phase one you must run
|
||||||
pg_upgrade with your old database installation in place. In phase two,
|
\fBpg_upgrade\fP with your old database installation in place. In phase two,
|
||||||
pg_upgrade must be run on a freshly initdb'ed current install.
|
\fBpg_upgrade\fP must be run on a freshly \fBinitdb\fP'ed current install.
|
||||||
In both phases, the same pg_upgrade script matching the newly installed
|
In both phases, the same \fBpg_upgrade\fP script matching the newly installed
|
||||||
version must be used.
|
version must be used.
|
||||||
.SH Upgrading PostgreSQL with pg_upgrade
|
.SH Upgrading PostgreSQL with pg_upgrade
|
||||||
.LP
|
.LP
|
||||||
1) Back up your existing data directory, preferably by making a complete
|
1) Back up your existing data directory, preferably by making a complete
|
||||||
dump with pg_dumpall.
|
dump with \fBpg_dumpall.\fP
|
||||||
.LP
|
.LP
|
||||||
2) Copy the program \fIpgsql/contrib/pg_upgrade/pg_upgrade\fP from the current
|
2) Copy the program \fIpgsql/contrib/pg_upgrade/pg_upgrade\fP from the current
|
||||||
PostgreSQL distribution somewhere into your path.
|
PostgreSQL distribution somewhere into your path.
|
||||||
@ -27,6 +27,7 @@ PostgreSQL distribution somewhere into your path.
|
|||||||
.B $ pg_upgrade -1
|
.B $ pg_upgrade -1
|
||||||
.sp
|
.sp
|
||||||
to collect information about the old database needed for the upgrade.
|
to collect information about the old database needed for the upgrade.
|
||||||
|
You may use \fI-D\fP to specify the data directory, or use PGDATA.
|
||||||
.LP
|
.LP
|
||||||
4) Do:
|
4) Do:
|
||||||
.LP
|
.LP
|
||||||
@ -41,7 +42,7 @@ to install the new binaries.
|
|||||||
.B $ make install
|
.B $ make install
|
||||||
.sp
|
.sp
|
||||||
to install the \fIpg_resetxlog\fP utility which is needed by
|
to install the \fIpg_resetxlog\fP utility which is needed by
|
||||||
pg_upgrade.
|
\fBpg_upgrade\fP.
|
||||||
.LP
|
.LP
|
||||||
6) Run initdb to create a new template1 database containing the system
|
6) Run initdb to create a new template1 database containing the system
|
||||||
tables for the new release. Make sure you use settings similar to those
|
tables for the new release. Make sure you use settings similar to those
|
||||||
@ -51,7 +52,7 @@ used in your previous version.
|
|||||||
to the server until the upgrade is complete. You may wish to start the
|
to the server until the upgrade is complete. You may wish to start the
|
||||||
postmaster without -i or alter pg_hba.conf temporarily.)
|
postmaster without -i or alter pg_hba.conf temporarily.)
|
||||||
.LP
|
.LP
|
||||||
8) Change your working directory to the pgsql main directory, and type:
|
8) Change your working directory to the pgsql main directory again, and type:
|
||||||
.LP
|
.LP
|
||||||
.B $ pg_upgrade -2
|
.B $ pg_upgrade -2
|
||||||
.sp
|
.sp
|
||||||
@ -66,10 +67,10 @@ subdirectories.
|
|||||||
.LP
|
.LP
|
||||||
10) Carefully examine the contents of the upgraded databases. If you
|
10) Carefully examine the contents of the upgraded databases. If you
|
||||||
detect problems, you'll need to recover by restoring from your full
|
detect problems, you'll need to recover by restoring from your full
|
||||||
pg_dump backup. You can delete the \fIpg_upgrade_info/\fP directory when you
|
\fBpg_dumpall\fP backup. You can delete the \fIpg_upgrade_info/\fP directory when you
|
||||||
are satisfied.
|
are satisfied.
|
||||||
.LP
|
.LP
|
||||||
The upgraded databases will be in an un-vacuumed state. You will
|
The upgraded databases will be in an un-vacuumed state. You will
|
||||||
probably want to run a \fIVACUUM ANALYZE\fB before beginning production work.
|
probably want to run a \fIVACUUM ANALYZE\fP before beginning production work.
|
||||||
.SH SEE ALSO
|
.SH SEE ALSO
|
||||||
initdb(1), postmaster(1), pg_dump(1), pg_dumpall(1), vacuumdb(1)
|
initdb(1), postmaster(1), pg_dump(1), pg_dumpall(1), vacuumdb(1)
|
||||||
|
Loading…
Reference in New Issue
Block a user