- #!/bin/bash
- #==============================================================================
- # Copyright and license info is available in the LICENSE file included with
- # the Server Deployment Package (SDP), and also available online:
- # https://swarm.workshop.perforce.com/projects/perforce-software-sdp/view/main/LICENSE
- #------------------------------------------------------------------------------
- # Helix Server base init script
- # Do nothing unless $SDP_INSTANCE is defined.
- export SDP_INSTANCE=${1:-Unset}
- if [[ $SDP_INSTANCE == Unset ]]; then
- echo -e "\nError: The SDP_INSTANCE is not defined.\n."
- exit 1
- fi
- # Load SDP controlled shell environment.
- source /p4/common/bin/p4_vars "$SDP_INSTANCE"
- if [[ $? -ne 0 ]]; then
- echo -e "\nError: Failed to load SDP environment for instance $SDP_INSTANCE.\n"
- exit 1
- fi
- source $P4CBIN/backup_functions.sh
- if [[ $? -ne 0 ]]; then
- echo -e "\nError: Failed to load SDP lib $P4CBIN/backup_functions.sh.\n"
- exit 1
- fi
- LOGFILE=$LOGS/p4d_init.log
- THISSCRIPT=${0##*/}
- CMDLINE="$0 $*"
- set_vars
- if [[ $(id -u) -eq 0 ]]; then
- exec su - $OSUSER -c "$0 $*"
- elif [[ $(id -u -n) != $OSUSER ]]; then
- echo "$0 can only be run by root or $OSUSER"
- exit 1
- fi
- if [[ ! -x $P4DBIN ]]; then
- echo -e "\nError: $P4DBIN is not executable."
- exit 2;
- fi
- # Ensure that the '--pid-file' argument is provided, and add it if it is not.
- # This is intended to prevent problems upgrading the SDP in case the
- # /p4/common/config/p4_N.vars file isn't updated to use the new template.
- if [[ "$P4D_FLAGS" != *"--pid-file"* ]]; then
- export P4D_FLAGS="$P4D_FLAGS --pid-file"
- fi
- # For P4D 2017.1+, automatically replace '-d' with '--daemonsafe'.
- if [[ "$P4D_VERSION" > "2017.1" ]]; then
- export P4D_FLAGS=${P4D_FLAGS/ -d / --daemonsafe }
- fi
- log "\nCalled $THISSCRIPT called with command line:\n$CMDLINE"
- # See how we were called.
- case "${2:-usage}" in
- force_start)
- echo "Starting $P4DBIN $P4D_FLAGS" | tee -a $LOGFILE
- $P4DBIN $P4D_FLAGS 2>&1 | tee -a $LOGFILE
- ;;
- start)
- if [[ -r $P4ROOT/db.domain ]]; then
- echo Preflight check: $P4DBIN -r $P4ROOT -xvU | tee -a $LOGFILE
- $P4DBIN -r $P4ROOT -xvU >> $LOGFILE 2>&1
- ExitCode=$?
- echo EXIT_CODE=$ExitCode >> $LOGFILE
- if [[ $ExitCode -ne 0 ]]; then
- echo -e "\nError: DB check with 'p4d -xvU' failed. Database integrity is in question. Please Contact Perforce Support (support@perforce.com). The force_start option is availble, but not recommended. Review this file:\n$LOGFILE\n" | tee -a $LOGFILE
- fi
- fi
- echo "Setting P4JOURNAL in the database to $P4JOURNAL." | tee -a $LOGFILE
- echo $P4DBIN -r $P4ROOT -cset P4JOURNAL=$P4JOURNAL | tee -a $LOGFILE
- $P4DBIN -r $P4ROOT "-cset P4JOURNAL=$P4JOURNAL" 2>&1 | tee -a $LOGFILE
- # Rotate the journal when starting so that any corruption is at the end of the rotated journal.
- if [[ "$P4REPLICA" == "FALSE" ]] && [[ $EDGESERVER -eq 0 ]]; then
- get_journalnum
- p4d_truncate_journal
- fi
- echo "Starting $P4DBIN $P4D_FLAGS" | tee -a $LOGFILE
- $P4DBIN $P4D_FLAGS 2>&1 | tee -a $LOGFILE
- ;;
- status)
- if [[ -r $P4ROOT/server.pid ]]; then
- pid=$(cat $P4ROOT/server.pid)
- echo -e "\nThe $P4ROOT/server.pid file contains pid $pid. Pid info:" | tee -a $LOGFILE
- $PS -f -p $pid 2>&1 | tee -a $LOGFILE
- echo
- if [[ $? -ne 0 ]]; then
- echo -e "\nError: A server.pid file exists, but that process id is not running. This could indicate abnormal process termination.\n" | tee -a $LOGFILE
- fi
- fi
- $P4BIN -p $P4PORT -u $P4USER info -s 2>&1 | tee -a $LOGFILE
- ;;
- admin_stop)
- # If there is no server.pid file, shut down the old fashioned way.
- echo -n "Shutting down $P4DBIN: " | tee -a $LOGFILE
- if [[ "${P4REPLICA}" == "FALSE" ]]; then
- $P4CBIN/p4login
- fi
- echo $P4BIN -p $P4PORT -u $P4USER admin stop | tee -a $LOGFILE
- $P4BIN -p $P4PORT -u $P4USER admin stop 2>&1 | tee -a $LOGFILE
- sleep 5
- $P4BIN -p $P4PORT info > /dev/null 2>&1
- ExitCode=$?
- if [[ $ExitCode -eq 0 ]]; then
- echo -e "\nError: Server shutdown failed." | tee -a $LOGFILE
- exit 1
- else
- exit 0
- fi
- ;;
- stop)
- if [[ -r $P4ROOT/server.pid ]]; then
- pid=$(cat $P4ROOT/server.pid)
- $PS -p $pid > /dev/null 2>&1
- status=$?
- if [[ $status -eq 0 ]]; then
- echo -e "\nSending SIGTERM signal to pid $pid in $P4ROOT/server.pid." | tee -a $LOGFILE
- kill $pid 2>&1 | tee -a $LOGFILE
- sleep 1
- $PS -p $pid > /dev/null 2>&1
- status=$?
- if [[ $status -eq 0 ]]; then
- echo -n "Waiting for p4d to shutdown ..." | tee -a $LOGFILE
- while [[ $status -eq 0 ]]; do
- echo -n "."
- sleep 5
- $PS -p $pid > /dev/null 2>&1
- status=$?
- done
- fi
- echo -e "\nConfirmed shutdown of $P4DBIN." | tee -a $LOGFILE
- else
- echo -e "\nError: A server.pid file exists, but that process id is not running. This could indicate abnormal process termination.\n" | tee -a $LOGFILE
- exit 1
- fi
- else
- echo -e "\nWarning: Missing $P4ROOT/server.pid. Attempting shtudown with 'p4 admin stop'.\n" | tee -a $LOGFILE
- echo $0 $SDP_INSTANCE admin_stop | tee -a $LOGFILE
- $0 $SDP_INSTANCE admin_stop 2>&1 | tee -a $LOGFILE
- fi
- ;;
- restart)
- $0 $SDP_INSTANCE stop
- $0 $SDP_INSTANCE start
- ;;
- *)
- echo -e "\nUsage: $0 SDP_INSTANCE {start|stop|admin_stop|status|restart|force_start}\n"
- exit 1
- ;;
- esac
- exit 0
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#1 | 23314 | matt_peterson | integrate sdp version 23041 | 7 years ago | |
//guest/perforce_software/sdp/main/Server/Unix/p4/common/bin/p4d_base | |||||
#17 | 23044 | C. Thomas Tyler | Released SDP 2017.3.23041 (2017/10/24). Copy Up using 'p4 copy -r -b perforce_software-sd...p-dev'. « |
7 years ago | |
#16 | 22685 | Russell C. Jackson (Rusty) | Update main with current changes from dev. | 8 years ago | |
#15 | 20565 | C. Thomas Tyler | Released SDP 2016.1.20559 (2016/09/14). Copy Up using 'p4 copy -r -b perforce_software-sd...p-dev', with selective removal of work-in-progress files. « |
9 years ago | |
#14 | 20519 | C. Thomas Tyler | Released SDP 2016.1.20491 (2016/09/09). Copy Up using 'p4 copy -r -b perforce_software-sd...p-dev', with selective removal of work-in-progress files. « |
9 years ago | |
#13 | 20481 | C. Thomas Tyler | Released SDP 2016.1.20460. Copy Up using 'p4 copy -r... -b perforce_software-sdp-dev', with selective removal of changes related to work-in-progress files. « |
9 years ago | |
#12 | 20353 | C. Thomas Tyler | Released SDP 2016.1.20348. Copy Up using 'p4 copy -r -b perforce_software-sdp-dev', with... selective removal of changes related to work-in-progress changes. « |
9 years ago | |
#11 | 18688 | Russell C. Jackson (Rusty) | Copy dev to main | 9 years ago | |
#10 | 17315 | C. Thomas Tyler | Released SDP/MultiArch/2016.1/17297 (2016/02/03). Copy Up using 'p4 copy -r -b perforce..._software-sdp-dev'. « |
9 years ago | |
#9 | 16263 | Russell C. Jackson (Rusty) | Added shutdown check to init script and used it in weekly_sync_replica. | 9 years ago | |
#8 | 15856 | C. Thomas Tyler | Replaced the big license comment block with a shortened form referencing the LICENSE file... included with the SDP package, and also by the URL for the license file in The Workshop. « |
10 years ago | |
#7 | 15777 | C. Thomas Tyler | No functional changes. Style Policing only on bash scripts only. Normalized indentatio...n and line breaks, removed offending tabs, and general whitespace usage. « |
10 years ago | |
#6 | 15776 | C. Thomas Tyler | Fixed a typo, a spurious back-tick (`) character that somehow snuck in. Also fixed... some tab/whitespace inconsistency issues. « |
10 years ago | |
#5 | 15775 | Russell C. Jackson (Rusty) | Added test to only login on a master | 10 years ago | |
#4 | 13908 | C. Thomas Tyler | Pushing SDP 2015.1.13906. | 10 years ago | |
#3 | 12171 | Russell C. Jackson (Rusty) | Merge in changes to remove the need for p4master_run. | 10 years ago | |
#2 | 11524 | Russell C. Jackson (Rusty) | Released updated version of the SDP from Dev. | 10 years ago | |
#1 | 10148 | C. Thomas Tyler | Promoted the Perforce Server Deployment Package to The Workshop. | 11 years ago |