forked from awslabs/pgbouncer-fast-switchover
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathadaptivepgbouncer.sh
executable file
·75 lines (74 loc) · 2.61 KB
/
adaptivepgbouncer.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
#!/bin/bash
netstat=$(mktemp)
n_db_conn=$default_pool_size
new_pgb_proc=0
while true
do
current_pod_age=$(kubectl get po $POD_NAME | awk '{print $NF}'|grep -E 'm|h' |awk -F\m '{print $1}'| awk -F\h '{print $1}' | awk -F\d '{print $1}')
if [ -z "$current_pod_age" ]
then
echo "current_pod_age is too young (empty); continue"
continue
fi
echo "current_pod_age="$current_pod_age
if (( $current_pod_age < 5 ))
then
echo "too young pod; continue"
continue
fi
current_pgb_proc=$(kubectl get deploy pgbouncer | grep -v NAME| awk '{print $3}')
current_n_conn=$(echo $(( $current_pgb_proc * $n_db_conn )))
echo "current_pgb_proc="$current_pgb_proc
echo "current_n_conn="$current_n_conn
if (( $current_n_conn > 4000 ))
then
echo "more than 4000 conn; skip scale up"
is_max=1
else
is_max=0
fi
netstat -an| grep tcp| awk '{print $NF}'|sort | uniq -c | awk '{printf "%s %s\n",$2,$1}' > $netstat
established_conn=$(cat $netstat | grep ESTABLISHED | awk '{print $2}')
echo "established_conn="$established_conn
if [ -z "$established_conn" ]
then
echo "established_conn is empty; continue"
continue
fi
echo "n_db_conn="$n_db_conn
echo "handling scale up"
if (( $established_conn >= $n_db_conn )) && (( $is_max == 0 ))
then
new_pgb_proc=$(echo $(( $current_pgb_proc + 10 )))
echo "pod is at max capacity. scaling faster from "$current_pgb_proc" to "$new_pgb_proc
else
if (( $established_conn >= $n_db_conn / 2 )) && (( $is_max == 0 ))
then
new_pgb_proc=$(echo $(( $current_pgb_proc + 1 )))
echo "pod is at 50% of its capacity. scaling up from "$current_pgb_proc" to "$new_pgb_proc
fi
fi
echo "handling scale down"
if (( $established_conn <= $n_db_conn / 5 ))
then
new_pgb_proc=$(echo $(( $current_pgb_proc - 1 )))
echo "pod is at 10% of its capacity. scaling down from "$current_pgb_proc" to "$new_pgb_proc
fi
echo "new_pgb_proc="$new_pgb_proc
if (( $new_pgb_proc > 0 ))
then
echo aws cloudwatch put-metric-data --metric-name num_pgb_proc --namespace pgbouncer --value $new_pgb_proc
aws cloudwatch put-metric-data --metric-name num_pgb_proc --namespace pgbouncer --value $new_pgb_proc
echo "cloudwatch exit code="$?
if (( $?>0 ))
then
echo "ERR-CW"
fi
echo kubectl scale deploy pgbouncer --replicas=$new_pgb_proc
kubectl scale deploy pgbouncer --replicas=$new_pgb_proc
new_pgb_proc=0
else
echo "no need to scale; established_conn="$established_conn" and n_db_conn="$n_db_conn
fi
sleep $(awk -v min=240 -v max=360 'BEGIN{srand(); print int(min+rand()*(max-min+1))}')
done