-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdbctl
executable file
·48 lines (48 loc) · 2.1 KB
/
dbctl
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
#!/bin/bash
case $1 in
up)
psql stillebot -c "begin read write; alter database stillebot reset default_transaction_read_only; commit; notify readonly, 'off';"
;;
dn|down)
psql stillebot -c "alter database stillebot set default_transaction_read_only = on; notify readonly, 'on';"
;;
refreshrepl)
sudo sudo -u postgres psql stillebot -c "set default_transaction_read_only = false" -c "alter subscription multihome refresh publication with (copy_data = false);"
;;
ac|activate)
psql stillebot <<EOF
\set instance_config \`cat `dirname $0`/instance-config.json\`
select active_bot from stillebot.settings;
update stillebot.settings set active_bot = :'instance_config'::jsonb ->> 'local_address';
select active_bot from stillebot.settings;
EOF
;;
stat|status)
psql stillebot -Atc "
show default_transaction_read_only;
select active_bot from stillebot.settings;
select pid from pg_stat_subscription where subname = 'multihome';
select client_addr, application_name, xact_start, state from pg_stat_activity where usename = 'rosuav' and pid != pg_backend_pid();
" | pike dbstatus.pike
;;
repl)
# A bit messy, but I want to do *one* database query to the remote server, and
# collect two pieces of information, one of which is needed by the script itself.
ACTIVE=`psql stillebot -Atc 'select active_bot from stillebot.settings'`
echo "Active database: $ACTIVE"
INFO=`psql -q "host=$ACTIVE user=rosuav dbname=stillebot sslcert=certificate.pem sslkey=privkey.pem" \
-c "select active, confirmed_flush_lsn from pg_replication_slots" \
-c "\pset format unaligned" -c "\pset tuples_only" \
-c "select client_addr from pg_replication_slots join pg_stat_activity on pid = active_pid"`
echo "$INFO" # Show the info to the user.
INACTIVE=`echo "$INFO" | tail -n 1` # And grab the last line for ourselves.
psql "host=$INACTIVE user=rosuav dbname=stillebot sslcert=certificate.pem sslkey=privkey.pem" \
-c "select received_lsn, latest_end_lsn from pg_stat_subscription"
;;
log|tail|logs)
tail -F /var/log/postgresql/postgresql-16-main.log
;;
*)
echo "Usage: $0 up|dn|status|log"
;;
esac