mirror of
https://github.com/goharbor/harbor.git
synced 2024-11-25 11:46:43 +01:00
aaea068cce
Fix #18338 Signed-off-by: Yang Jiao <jiaoya@vmware.com> Co-authored-by: Wang Yan <wangyan@vmware.com>
72 lines
3.2 KiB
Bash
72 lines
3.2 KiB
Bash
#!/bin/bash
|
||
set -e
|
||
|
||
source $PWD/initdb.sh
|
||
|
||
CUR=$PWD
|
||
PG_VERSION_OLD=$1
|
||
PG_VERSION_NEW=$2
|
||
|
||
PGBINOLD="/usr/pgsql/${PG_VERSION_OLD}/bin"
|
||
|
||
PGDATAOLD=${PGDATA}/pg${PG_VERSION_OLD}
|
||
PGDATANEW=${PGDATA}/pg${PG_VERSION_NEW}
|
||
|
||
# We should block the upgrade path from 9.6 directly.
|
||
if [ -s $PGDATA/PG_VERSION ]; then
|
||
echo "Upgrading from PostgreSQL 9.6 to PostgreSQL $PG_VERSION_NEW is not supported in the current Harbor release."
|
||
echo "You should upgrade to previous Harbor firstly, then upgrade to current release."
|
||
exit 1
|
||
fi
|
||
|
||
# Upgrade DB: 1. PG_NEW\PG_VERSION file doesn’t exist and pg_old_parameter is not nil and PG_OLD\PG_VERSION file exist.
|
||
# For example: ["13", "14"]
|
||
# In harbor v2.8, Harbor 2.7 was installed before, db version was 13,
|
||
# It needs to upgrade the database from pg 13 to pg 14,
|
||
# ["13", "14"] means support for upgrading from pg 13 to pg 14.
|
||
# Init DB: 1. PG_NEW\PG_VERSION file doesn’t exist and pg_old_parameter is not nil and PG_OLD\PG_VERSION file doesn’t exist.
|
||
# For example: ["13", "14"]
|
||
# In harbor v2.8, the first time installation, it needs to init the db for pg 14,
|
||
# ["13", "14"] means support for upgrading from pg 13 to pg 14.
|
||
# 2. PG_NEW\PG_VERSION file doesn’t exist and pg_old_parameter is nil.
|
||
# For example: ["", "14"]
|
||
# In harbor v2.8, the first time installation, it needs to init the db for pg 14,
|
||
# ["", "14"] means db upgrade is not supported.
|
||
if [ ! -s $PGDATANEW/PG_VERSION ]; then
|
||
if [ ! -z $PG_VERSION_OLD ] && [ -s $PGDATAOLD/PG_VERSION ]; then
|
||
echo "upgrade DB from $PG_VERSION_OLD to $PG_VERSION_NEW"
|
||
initPG $PGDATANEW false
|
||
set +e
|
||
# In some cases, like helm upgrade, the postgresql may not quit cleanly.
|
||
# Use start & stop to clean the unexpected status. Error:
|
||
# There seems to be a postmaster servicing the new cluster.
|
||
# Please shutdown that postmaster and try again.
|
||
# Failure, exiting
|
||
$PGBINOLD/pg_ctl -D "$PGDATAOLD" -w -o "-p 5433" start
|
||
$PGBINOLD/pg_ctl -D "$PGDATAOLD" -m fast -w stop
|
||
./$CUR/upgrade.sh --old-bindir $PGBINOLD --old-datadir $PGDATAOLD --new-datadir $PGDATANEW
|
||
# it needs to clean the $PGDATANEW on upgrade failure
|
||
if [ $? -ne 0 ]; then
|
||
echo "remove the $PGDATANEW after fail to upgrade."
|
||
rm -rf $PGDATANEW
|
||
exit 1
|
||
fi
|
||
set -e
|
||
echo "remove the $PGDATAOLD after upgrade success."
|
||
rm -rf $PGDATAOLD
|
||
else
|
||
echo "init DB, DB version:$PG_VERSION_NEW"
|
||
initPG $PGDATANEW true
|
||
fi
|
||
fi
|
||
|
||
POSTGRES_PARAMETER=''
|
||
file_env 'POSTGRES_MAX_CONNECTIONS' '1024'
|
||
# The max value of 'max_connections' is 262143
|
||
if [ $POSTGRES_MAX_CONNECTIONS -le 0 ] || [ $POSTGRES_MAX_CONNECTIONS -gt 262143 ]; then
|
||
POSTGRES_MAX_CONNECTIONS=262143
|
||
fi
|
||
|
||
POSTGRES_PARAMETER="${POSTGRES_PARAMETER} -c max_connections=${POSTGRES_MAX_CONNECTIONS}"
|
||
exec postgres -D $PGDATANEW $POSTGRES_PARAMETER
|