#!/bin/bash
#------------------------------------------------------------------------------
# Copyright (c) Perforce Software, Inc., 2007-2014. All rights reserved
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# 1 Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL PERFORCE
# SOFTWARE, INC. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
# ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
# TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
# DAMAGE.
#------------------------------------------------------------------------------
. /p4/common/bin/backup_functions.sh
recreate_offline_db_files_2013.3 () {
log "Recreate offline db files for 2013.3 upgrade process."
rm -f ${OFFLINE_DB}/db.* >> "$LOGFILE"
# curly braces are necessary to capture the output of 'time'
# if $P4DBIN is not a link, then it is a wrapper around p4d with the -C1 flag.
if [ ! -L $P4DBIN ]; then
{ time /p4/common/bin/p4d_${P4DRELNUM}_bin -C1 -r $OFFLINE_DB -J off -jr -z ${CHECKPOINTS}/${P4SERVER}.ckp.${JOURNALNUM}.gz; } >> "$LOGFILE" 2>&1 || \
{ log "ERROR - Restore of checkpoint to $OFFLINE_DB failed!"; }
else
{ time /p4/common/bin/p4d_${P4DRELNUM}_bin -r $OFFLINE_DB -J off -jr -z ${CHECKPOINTS}/${P4SERVER}.ckp.${JOURNALNUM}.gz; } >> "$LOGFILE" 2>&1 || \
{ log "ERROR - Restore of checkpoint to $OFFLINE_DB failed!"; }
fi
}
switch_db_files () {
log "Switching out db files..."
[ -d $SAVEDIR ] || mkdir -p $SAVEDIR
rm -f $SAVEDIR/db.* >> $LOGFILE 2>&1
mv $P4ROOT/db.* $SAVEDIR >> $LOGFILE 2>&1
mv $OFFLINE_DB/db.* $P4ROOT >> $LOGFILE 2>&1 || die "Move of offline db file to $P4ROOT failed."
}
AWK=awk
ID=id
MAIL=mail
OS=`uname`
if [ "${OS}" = "SunOS" ] ; then
AWK=/usr/xpg4/bin/awk
ID=/usr/xpg4/bin/id
MAIL=mailx
elif [ "${OS}" = "AIX" ] ; then
AWK=awk
ID=id
MAIL=mail
fi
export AWK
export ID
export MAIL
cd /p4/common/bin
common_dir=`pwd -P`
if [ -d $common_dir ]; then
cd $common_dir
else
echo $common_dir does not exist.
exit 1
fi
######### Start of Script ##########
check_vars
set_vars
check_dirs
[ -f $common_dir/p4 ] || { echo "No p4 in $common_dir" ; exit 1 ;}
[ -f $common_dir/p4d ] || { echo "No p4d in $common_dir" ; exit 1 ;}
chmod 777 $common_dir/p4
chmod 700 $common_dir/p4d
P4RELNUM=`./p4 -V | grep -i Rev. | $AWK -F / '{print $3}'`
P4DRELNUM=`./p4d -V | grep -i Rev. | $AWK -F / '{print $3}'`
P4BLDNUM=`./p4 -V | grep -i Rev. | $AWK -F / '{print $4}' | awk '{print $1}'`
P4DBLDNUM=`./p4d -V | grep -i Rev. | $AWK -F / '{print $4}' | awk '{print $1}'`
CURRENT_RELNUM=`./p4d_${P4INSTANCE}_bin -V | grep -i Rev. | $AWK -F / '{print $3}'`
LOGFILE=$LOGDIR/upgrade.log
if [ -f $LOGFILE ]
then
rm -f $LOGFILE
fi
log "Start $P4SERVER Upgrade"
/p4/common/bin/p4login
get_journalnum
[ -f ${CHECKPOINTS}/${P4SERVER}.ckp.${JOURNALNUM}.gz ] || { echo "Checkpoint ${CHECKPOINTS}/${P4SERVER}.ckp.${JOURNALNUM}.gz missing!" ; exit 1 ;}
[ -f p4_$P4RELNUM.$P4BLDNUM ] || cp p4 p4_$P4RELNUM.$P4BLDNUM
[ -f p4d_$P4DRELNUM.$P4DBLDNUM ] || cp p4d p4d_$P4DRELNUM.$P4DBLDNUM
[ -f p4_${P4RELNUM}_bin ] && unlink p4_${P4RELNUM}_bin
ln -s p4_$P4RELNUM.$P4BLDNUM p4_${P4RELNUM}_bin >> "$LOGFILE" 2>&1
[ -f p4d_${P4DRELNUM}_bin ] && unlink p4d_${P4DRELNUM}_bin
ln -s p4d_$P4DRELNUM.$P4DBLDNUM p4d_${P4DRELNUM}_bin >> "$LOGFILE" 2>&1
[ -f p4_bin ] && unlink p4_bin
ln -s p4_${P4RELNUM}_bin p4_bin >> "$LOGFILE" 2>&1
recreate_offline_db_files_2013.3
stop_p4d
sleep 5
truncate_journal
log "Changing p4d link to new version."
unlink p4d_${P4INSTANCE}_bin >> "$LOGFILE" 2>&1
ln -s p4d_${P4DRELNUM}_bin p4d_${P4INSTANCE}_bin >> "$LOGFILE" 2>&1
replay_journal_to_offline_db
log "Upgrading $OFFLINE_DB"
$P4DBIN -r $OFFLINE_DB -J off -xu >> "$LOGFILE" 2>&1
switch_db_files
start_p4d
log "Removing db files from $SAVEDIR"
rm -f ${SAVEDIR}/db.* >> "$LOGFILE"
recreate_offline_db_files_2013.3
replay_journal_to_offline_db
log "Upgrading $OFFLINE_DB"
$P4DBIN -r $OFFLINE_DB -J off -xu >> "$LOGFILE" 2>&1
ROOTDIR=$OFFLINE_DB
dump_checkpoint
remove_old_checkpoints_and_journals
log "Finish $P4SERVER Upgrade"
| # | Change | User | Description | Committed | |
|---|---|---|---|---|---|
| #3 | 15789 | alan_petersen | Merging latest revision | ||
| #2 | 15465 | alan_petersen | Merging using sdp_alan_petersen | ||
| #1 | 10151 | alan_petersen |
Populate //guest/alan_petersen/sdp/... from //guest/perforce_software/sdp/.... |
||
| //guest/perforce_software/sdp/main/Server/Unix/p4/common/bin/2013.3_upgrade.sh | |||||
| #1 | 10148 | C. Thomas Tyler | Promoted the Perforce Server Deployment Package to The Workshop. | ||