forked from metabrainz/musicbrainz-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupgrade.sh
executable file
·106 lines (80 loc) · 3.78 KB
/
upgrade.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#!/bin/bash -u
set -o errexit
cd `dirname $0`
eval `./admin/ShowDBDefs`
NEW_SCHEMA_SEQUENCE=22
OLD_SCHEMA_SEQUENCE=$((NEW_SCHEMA_SEQUENCE - 1))
################################################################################
# Assert pre-conditions
if [ "$DB_SCHEMA_SEQUENCE" != "$OLD_SCHEMA_SEQUENCE" ]
then
echo `date` : Error: Schema sequence must be $OLD_SCHEMA_SEQUENCE when you run this script
exit -1
fi
################################################################################
# Backup and disable replication triggers
if [ "$REPLICATION_TYPE" = "$RT_MASTER" ]
then
echo `date` : Export pending db changes
./admin/RunExport
echo `date`" : Bundling replication packets, daily"
./admin/replication/BundleReplicationPackets $FTP_DATA_DIR/replication --period daily --require-previous
echo `date`" : + weekly"
./admin/replication/BundleReplicationPackets $FTP_DATA_DIR/replication --period weekly --require-previous
echo `date` : 'Drop replication triggers (musicbrainz)'
./admin/psql MAINTENANCE < ./admin/sql/DropReplicationTriggers.sql
for schema in caa documentation statistics wikidocs
do
echo `date` : "Drop replication triggers ($schema)"
./admin/psql MAINTENANCE < ./admin/sql/$schema/DropReplicationTriggers.sql
done
fi
if [ "$REPLICATION_TYPE" != "$RT_SLAVE" ]
then
echo `date` : Disabling last_updated triggers
./admin/sql/DisableLastUpdatedTriggers.pl
fi
################################################################################
# Migrations that apply for only slaves
if [ "$REPLICATION_TYPE" = "$RT_SLAVE" ]
then
echo `date` : 'Running upgrade scripts for slave nodes'
./admin/psql MAINTENANCE < ./admin/sql/updates/schema-change/${NEW_SCHEMA_SEQUENCE}.slave_only.sql || exit 1
fi
################################################################################
# Scripts that should run on *all* nodes (master/slave/standalone)
echo `date` : 'Running upgrade scripts for all nodes'
./admin/psql MAINTENANCE < ./admin/sql/updates/schema-change/${NEW_SCHEMA_SEQUENCE}.slave.sql || exit 1
################################################################################
# Re-enable replication
if [ "$REPLICATION_TYPE" = "$RT_MASTER" ]
then
echo `date` : 'Create replication triggers (musicbrainz)'
OUTPUT=`./admin/psql MAINTENANCE < ./admin/sql/CreateReplicationTriggers.sql 2>&1` || ( echo "$OUTPUT" ; exit 1 )
for schema in caa documentation statistics wikidocs
do
echo `date` : "Create replication triggers ($schema)"
OUTPUT=`./admin/psql MAINTENANCE < ./admin/sql/$schema/CreateReplicationTriggers.sql 2>&1` || ( echo "$OUTPUT" ; exit 1 )
done
fi
################################################################################
# Add constraints that apply only to master/standalone (FKS)
if [ "$REPLICATION_TYPE" != "$RT_SLAVE" ]
then
echo `date` : 'Running upgrade scripts for master/standalone nodes'
./admin/psql MAINTENANCE < ./admin/sql/updates/schema-change/${NEW_SCHEMA_SEQUENCE}.standalone.sql || exit 1
echo `date` : Enabling last_updated triggers
./admin/sql/EnableLastUpdatedTriggers.pl
fi
################################################################################
# Bump schema sequence
echo `date` : Going to schema sequence $NEW_SCHEMA_SEQUENCE
echo "UPDATE replication_control SET current_schema_sequence = $NEW_SCHEMA_SEQUENCE;" | ./admin/psql MAINTENANCE
# ignore superuser-only vacuum tables
echo `date` : Vacuuming DB.
echo "VACUUM ANALYZE;" | ./admin/psql MAINTENANCE 2>&1 | grep -v 'only superuser can vacuum it'
################################################################################
# Prompt for final manual intervention
echo `date` : Done
echo `date` : UPDATE THE DB_SCHEMA_SEQUENCE IN DBDefs.pm TO $NEW_SCHEMA_SEQUENCE !
# eof