generated from ucsd-ets/datahub-example-notebook
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstart_single_user_postgres.sh
111 lines (92 loc) · 4.33 KB
/
start_single_user_postgres.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
107
108
109
110
111
###################
###################
###################
# This helper script initializes a local Postgresql database and configures it appropriately.
# This includes modifying the inherited postgresql.yml config, creating appropriate directories,
# starting postgres as a non-root user, and setting user credentials in postgresql.
# Environment variables that are not initialized here are initialized by the launch script referenced in the README.
# 8/10/2023 dafeliton
###################
###################
###################
#!/bin/bash
# If pgdata exists, stop or start depending on if PID file exists
if [ -d "${HOME}/pgdata" ]; then
echo "pgdata/ already exists."
if [ -f "${HOME}/pgdata/pgsql-main.pd" ]; then
# Stop postgres
echo "Stopping postgres..."
pg_ctl -D "${HOME}/pgdata/" -l "${HOME}/logfile" stop
else
# Start postgres
echo "Starting postgres..."
pg_ctl -D "${HOME}/pgdata/" -l "${HOME}/logfile" start
fi
exit 0
fi
# Setup vars + ensure pgdata exists
initdb -D pgdata
mkdir "/home/${USER}/pgdata/conf.d" 2>/dev/null
PGDATA="${HOME}/pgdata"
PGCONFIGFILE="${HOME}/pgdata/postgresql.conf"
PGHBAFILE="${HOME}/pgdata/pg_hba.conf"
PGIDENTFILE="${HOME}/pgdata/pg_ident.conf"
PGPIDFILE="${HOME}/pgdata/pgsql-main.pd"
PGUNIXSOCKETDIRS="${HOME}/pgdata/"
CONFIGFILE="/etc/postgresql/${POSTGRES_VERSION}/main/postgresql.conf"
TEMPCONFIGFILE="${HOME}/temp_post.yml"
HBAFILE="/etc/postgresql/${POSTGRES_VERSION}/main/pg_hba.conf"
IDENTFILE="/etc/postgresql/${POSTGRES_VERSION}/main/pg_ident.conf"
# Copy config file
echo "Overwriting + modifying configs..."
# Modify PostgreSQL configuration, preserve any other values
awk -F " *= *" \
-v PGDATA="$PGDATA" \
-v PGHBAFILE="$PGHBAFILE" \
-v PGIDENTFILE="$PGIDENTFILE" \
-v PGPIDFILE="$PGPIDFILE" \
-v PGUNIXSOCKETDIRS="$PGUNIXSOCKETDIRS" \
'{
gsub(/^[ \t]+/, "", $1);
if ($1 == "data_directory") { print $1 " = '\''" PGDATA "'\''"; next }
if ($1 == "hba_file") { print $1 " = '\''" PGHBAFILE "'\''"; next }
if ($1 == "ident_file") { print $1 " = '\''" PGIDENTFILE "'\''"; next }
if ($1 == "external_pid_file") { print $1 " = '\''" PGPIDFILE "'\''"; next }
if ($1 == "unix_socket_directories") { print $1 " = '\''" PGUNIXSOCKETDIRS "'\''"; next }
print $0
}' "$CONFIGFILE" > "$TEMPCONFIGFILE"
# Remove unnecessary value from config
awk '!/^stats_temp_directory/' "$TEMPCONFIGFILE" > "${TEMPCONFIGFILE}.tmp" && mv "${TEMPCONFIGFILE}.tmp" "$TEMPCONFIGFILE"
# Disable SSL (for now?)
awk '{gsub(/ssl[ \t]*=[ \t]*on/, "ssl = off"); print}' "$TEMPCONFIGFILE" > "${TEMPCONFIGFILE}.tmp" && mv "${TEMPCONFIGFILE}.tmp" "$TEMPCONFIGFILE"
# Write config file
mv "$TEMPCONFIGFILE" "$PGCONFIGFILE"
# Write hba file
cp "$HBAFILE" "$PGHBAFILE"
# Write ident file
cp "$IDENTFILE" "$PGIDENTFILE"
# Initialize server, create DB
cd "${HOME}"
pg_ctl -D "${HOME}/pgdata/" -l "${HOME}/logfile" start
createdb -O "${USER}" rsm-docker -p 8765 -h "${HOME}/pgdata/"
psql rsm-docker -U "${USER}" -h "${HOME}/pgdata/" -p 8765 -c "ALTER USER ${USER} WITH PASSWORD '${PGPASSWORD}';"
echo "#####################################################################################"
echo "#####################################################################################"
echo "#####################################################################################"
echo ""
echo ""
echo ""
echo "Your local, non-root postgres server has been started."
echo "All data is stored in /home/${USER}/pgdata. Please DELETE this dir if you need to init your database setup again."
echo ""
echo "Please write down these commands! You will need to run this if your environment is interrupted."
echo "To START your local postgres server ----> pg_ctl -D ${HOME}/pgdata -l ${HOME}/logfile start"
echo "To STOP your local postgres server ----> pg_ctl -D ${HOME}/pgdata -l ${HOME}/logfile stop"
echo "Running this script from this point onwards will do the inverse of the DB's state (shorthand for the above commands)."
echo "If it is shutdown, it will be started. If it is active, it will be shutdown."
echo ""
echo ""
echo ""
echo "#####################################################################################"
echo "#####################################################################################"
echo "#####################################################################################"