aboutsummaryrefslogtreecommitdiff
path: root/modules/private/monitoring/plugins/check_postgres_database_count
blob: 43bdd8cec22c7d67f759f99d28aea549d9c06a04 (plain) (blame)
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
#!/bin/bash

STATE_OK=0
STATE_WARNING=1
STATE_CRITICAL=2
STATE_UNKNOWN=3

host=$1
port=$2
min=$3

count=$(psql -h $host -p $port -A -q -c '\t' -c 'select count(datname) from pg_catalog.pg_database' postgres 2>&1)
exit_code=$?

if [[ $exit_code -ne 0 ]]; then
  echo "UNKNOWN - Impossible to run psql command: $count"
  exit $STATE_UNKNOWN
elif [[ -z "$count" ]]; then
  echo "UNKNOWN - No database found"
  exit $STATE_UNKNOWN
else
  output="Database count is $count"
  LC_ALL=C count=$(printf "%.*f" 0 $count)

  if [[ $count -gt $min ]]; then
    echo "OK - $output | count=${count};$min;$min;0;"
    exit $STATE_OK
  else
    echo "CRITICAL - $output | count=${count};$min;$min;0;"
    exit $STATE_CRITICAL
  fi
fi