123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- #!/bin/bash
- # Skip Unbound (DNS Resolver) Healthchecks (NOT Recommended!)
- if [[ "${SKIP_UNBOUND_HEALTHCHECK}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
- SKIP_UNBOUND_HEALTHCHECK=y
- fi
- # Declare log function for logfile inside container
- function log_to_file() {
- echo "$(date +"%Y-%m-%d %H:%M:%S"): $1" > /var/log/healthcheck.log
- }
- # General Ping function to check general pingability
- function check_ping() {
- declare -a ipstoping=("1.1.1.1" "8.8.8.8" "9.9.9.9")
- for ip in "${ipstoping[@]}" ; do
- ping -q -c 3 -w 5 "$ip"
- if [ $? -ne 0 ]; then
- log_to_file "Healthcheck: Couldn't ping $ip for 5 seconds... Gave up!"
- log_to_file "Please check your internet connection or firewall rules to fix this error, because a simple ping test should always go through from the unbound container!"
- return 1
- fi
- done
- log_to_file "Healthcheck: Ping Checks WORKING properly!"
- return 0
- }
- # General DNS Resolve Check against Unbound Resolver himself
- function check_dns() {
- declare -a domains=("mailcow.email" "github.com" "hub.docker.com")
- for domain in "${domains[@]}" ; do
- for ((i=1; i<=3; i++)); do
- dig +short +timeout=2 +tries=1 "$domain" @127.0.0.1 > /dev/null
- if [ $? -ne 0 ]; then
- log_to_file "Healthcheck: DNS Resolution Failed on $i attempt! Trying again..."
- if [ $i -eq 3 ]; then
- log_to_file "Healthcheck: DNS Resolution not possible after $i attempts... Gave up!"
- log_to_file "Maybe check your outbound firewall, as it needs to resolve DNS over TCP AND UDP!"
- return 1
- fi
- fi
- done
- done
- log_to_file "Healthcheck: DNS Resolver WORKING properly!"
- return 0
-
- }
- # Simple Netcat Check to connect to common webports
- function check_netcat() {
- declare -a domains=("mailcow.email" "github.com" "hub.docker.com")
- declare -a ports=("80" "443")
- for domain in "${domains[@]}" ; do
- for port in "${ports[@]}" ; do
- nc -z -w 2 $domain $port
- if [ $? -ne 0 ]; then
- log_to_file "Healthcheck: Could not reach $domain on Port $port... Gave up!"
- log_to_file "Please check your internet connection or firewall rules to fix this error."
- return 1
- fi
- done
- done
- log_to_file "Healthcheck: Netcat Checks WORKING properly!"
- return 0
- }
- if [[ ${SKIP_UNBOUND_HEALTHCHECK} == "y" ]]; then
- log_to_file "Healthcheck: ALL CHECKS WERE SKIPPED! Unbound is healthy!"
- exit 0
- fi
- # run checks, if check is not returning 0 (return value if check is ok), healthcheck will exit with 1 (marked in docker as unhealthy)
- check_ping
- if [ $? -ne 0 ]; then
- exit 1
- fi
- check_dns
- if [ $? -ne 0 ]; then
- exit 1
- fi
- check_netcat
- if [ $? -ne 0 ]; then
- exit 1
- fi
- log_to_file "Healthcheck: ALL CHECKS WERE SUCCESSFUL! Unbound is healthy!"
- exit 0
|