====== Docker Compose Icinga stack ======
Quelle: https://github.com/lippserd/docker-compose-icinga
Stack nach Anleitung von Github herunterladen und im Verzeichnis folgende Änderungen vornehmen:
- Eingebaute Host-Konfiguration entfernen (wird dann im Director konfiguriert) \\ Datei /etc/icinga2/conf.d/hosts.conf löschen lassen \\ in Datei ''init-icinga2.sh'' unten einfügen if [ -f /data/etc/icinga2/conf.d/hosts.conf ]; then
rm -F /data/etc/icinga2/conf.d/hosts.conf
fi
- Passwort von "icingaadmin" ändern \\ in Datei ''docker-compose.yml'' die Zeile ''icingaweb.passwords.icingaweb2.icingaadmin:''
- Icinga Stack starten cd /opt/docker-compose-icinga
docker compose up -d
- Icinga Stack stoppen docker compose down
- Wiederherstellen der Standard-Benutzerrollen unterbinden \\ in Datei ''docker-compose.yml'' die Zeilen auskommentieren \\ ''icingaweb.roles.Administrators.groups: Administrators'' \\ ''icingaweb.roles.Administrators.permissions: '*' '' \\ ''icingaweb.roles.Administrators.users: icingaadmin''
- Icinga Stack starten docker compose up -d
- Icinga nach reboot automatisch starten ''systemctl edit --full docker-compose-icinga.service'' Unit]
Description=Start Icinga-Playground Docker containers
After=docker.service
Requires=docker.service
[Service]
Type=oneshot
RemainAfterExit=yes
WorkingDirectory=/opt/docker-compose-icinga
User=linux
Group=docker
#ExecStart=docker compose -p icinga-playground up -d
#ExecStop=docker compose -p icinga-playground stop
ExecStart=docker compose up -d
ExecStop=docker compose stop
TimeoutStartSec=0
[Install]
WantedBy=multi-user.target
Danach den Service einschalten und den Systemd-Daemon neustarten ''systemctl enable docker-compose-icinga.service && systemctl daemon-reload''
===== Eigene Checks einbinden =====
In den Icinga2 Container verbinden und folgendes ausführen:
echo "include_recursive \"/custom_data/custom.conf.d/\"" >> /etc/icinga2/icinga2.conf
Danach auf dem Docker-Host den Ordner für die eigenen Checks erstellen und Checks dort ablegen.
mkdir -p /opt/docker-compose-icinga/icinga2.conf.d/my-plugins/
Hier ein Check zum Überwachen von QNap-NAS (Quelle: siehe Inhalt):
#!/bin/bash
############################# Created and written by Matthias Luettermann ###############
#
#
# special thnaks to
# Nicola Bandini n.bandini@gmail.com
# Tom Lesniak and Hugo Geijteman
# for the nice and useful inspiratipon
#
# This progmem is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation;
#
# This progmem is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# contact the author directly for more information at: matthias@xcontrol.de
##########################################################################################
#Version 1.40
usage="
-ver Check_qnap Version
-C community default public
-t timeout default 10 secdons
-v snmpversion default 2c
-p snmpport defauilt 161
-a checks you can use
cpuload: check´s the system CPU load in perent
cputemp: check´s the sytem CPU Temperature
systemp: check´s the system Temperature
hdtemp: check´s the Harddive Temperature
diskusage: check´s the diskusage on perent
mem: check´s the mem usage in perent
volstatus: check´s the Volume status
fan: check´s the Fan Speed
hdstatus: check´s the Harddive status
cachediskstatus: check´s the Cachedisk status
lunstatus: check´s the LUN status
raidstatus: check´s the Raid status
powerstatus: check´s the Power status
sysinfo: provides the QNAP infos
example
check_qanp -H 192.168.0.2 -a mem
responce: OK: Memory Total=15976MB used=9177MB free:6799MB|Memory usage=43%;80;90;0;100
or
check_qanp -H myqnap.domain.com -C public -v 1 -p 123 -a cputemp -u F -w 40 -c 45 -t 60
checked host myqnap.domain.com
community public
snmpversion 1
snmpport 123
check cpu Temperature
unit fahrenheit
warning 40 F
critical 45 F
timeout 60 seconds
"
while getopts H:b:C:t:v:p:a:w:c:u:help:h option;
do
case $option in
H) hostaddress=$OPTARG;;
b) version=$OPTARG;;
C) community=$OPTARG;;
t) timeout=$OPTARG;;
v) snmpversion=$OPTARG;;
p) snmpport=$OPTARG;;
a) check=$OPTARG;;
w) warning=$OPTARG;;
c) critical=$OPTARG;;
u) unit=$OPTARG;;
h) help=1;;
esac
done
check()
{
if [[ "$help" == "1" ]]; then
echo "$usage"
exit;
fi
if [[ -z "$hostaddress" ]] || [[ -z "$check" ]] && [[ "$help" != "1" ]];then
echo "
** Hostaddress and checkprocedure are mandatory **
"
echo "$usage"
exit;
fi
}
check
if [[ -z "$community" ]]; then
community=public;
fi
if [[ -z "$timeout" ]]; then
timeout=10;
fi
if [[ -z "$snmpversion" ]]; then
snmpversion=2c;
fi
if [[ -z "$snmpport" ]]; then
snmpport=161;
fi
if [[ -z "$warning" ]]; then
warning=80;
fi
if [[ -z "$critical" ]]; then
critical=90;
fi
if [[ -z "$unit" ]]; then
unit=C;
fi
if [[ "$unit" == "C" ]]; then
var1="-c2-3";
if [[ "$check" == "cputemp" ]]; then
var2=20
var3=90
else
var2=20
var3=60
fi
else
var1="-c7-9";
if [[ "check" == "cputemp" ]]; then
var2=32
var3=194
else
var=32
var=140
fi
fi
output=""
niu=0
count=0
counter=0
status=""
criticalqty=0
warningqty=0
okqty=0
avg=0
mysnmpcheck="snmpget -v $snmpversion -c $community -t $timeout $hostaddress:$snmpport"
# DISKUSAGE
if [[ "$check" == "diskusage" ]]; then
capacity=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.17.1.4.1 | awk '{print $4}' | sed 's/.\(.*\)/\1/')
free=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.17.1.5.1 | awk '{print $4}' | sed 's/.\(.*\)/\1/')
unit=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.17.1.4.1 | awk '{print $5}' | sed 's/.*\(.B\).*/\1/')
unit2=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.17.1.5.1 | awk '{print $5}' | sed 's/.*\(.B\).*/\1/')
if [[ "$unit" == "TB" ]]; then
factor=$(echo "scale=0; 1000000" | bc -l)
elif [[ "$unit" == "GB" ]]; then
factor=$(echo "scale=0; 1000" | bc -l)
else
factor=$(echo "scale=0; 1" | bc -l)
fi
if [[ "$unit2" == "TB" ]]; then
factor2=$(echo "scale=0; 1000000" | bc -l)
elif [[ "$unit2" == "GB" ]]; then
factor2=$(echo "scale=0; 1000" | bc -l)
else
factor2=$(echo "scale=0; 1" | bc -l)
fi
capacitybytes=$(echo "scale=0; $capacity*$factor" | bc -l)
freebytes=$(echo "scale=0; $free*$factor2" | bc -l)
usedbytes=$(echo "scale=0; $capacitybytes-$freebytes" | bc -l)
used=$(echo "scale=0; $usedbytes/$factor" | bc -l)
usedperc=$(echo "scale=0; $usedbytes*100/$capacitybytes" | bc -l)
freeperc=$(echo "scale=0; $freebytes*100/$capacitybytes" | bc -l)
output="Total=$capacity $unit Used=$used $unit Free=$free $unittest2|Used=$usedperc%;$warning;$critical;0;100"
if [[ $usedperc -ge $critical ]]; then
echo "critical: "$output
exit 2
elif [[ $usedperc -ge $warning ]]; then
echo "warning: "$output
exit 1
else
echo "OK: "$output
exit 0
fi
# CPULOAD
elif [[ "$check" == "cpuload" ]]; then
cpuload=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.1.0 | awk '{print $4 $5}' | sed 's/.\(.*\)...../\1/')
output="CPU-load=$cpuload%|CPU-load=$cpuload%;$warning;$critical;0;100"
if [[ $cpuload -ge $critical ]]; then
echo "critical: "$output
exit 2
elif [[ $cpuload -ge $warning ]]; then
echo "warning: "$output
exit 1
else
echo "OK: "$output
exit 0
fi
# CPUTEMP
elif [[ "$check" == "cputemp" ]]; then
temp=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.5.0 | awk '{print $4,$5}' | cut $var1)
output="CPU-temperature=$temp $unit|CPU-temperature=$temp%unit;$warning;$critical;$var2;$var3"
if [[ $temp -ge $critical ]]; then
echo "critical: "$output
exit 2
elif [[ $temp -ge $warning ]]; then
echo "warning: "$output
exit 1
else
echo "OK: "$output
exit 0
fi
# System Temperature
elif [[ "$check" == "systemp" ]]; then
temp=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.6.0 | awk '{print $4,$5}' | cut $var1)
output="System-temperature=$temp $unit|System-temperature=$temp$unit;$warning;$critical;$var2;$var3"
if [[ $temp -ge $critical ]]; then
echo "critical: "$output
exit 2
elif [[ $temp -ge $warning ]]; then
echo "warning: "$output
exit 1
else
echo "OK: "$output
exit 0
fi
# HD Temperature
elif [[ "$check" == "hdtemp" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.10.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
temp=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.11.1.3.$c | awk '{print $4,$5}' | cut $var1)
if [[ "$temp" -ge "$critical" ]]; then
crt="$crt| HD-$c $temp $unit"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
avg=$(echo "scale=4; $avg + $temp" | tr , . | bc)
elif [[ "$temp" -ge "$warning" ]]; then
wrn="$wrn| HD-$c $temp $unit"
warningqty=$(echo "scale=0; $warningqty+1" | bc -l)
avg=$(echo "scale=4; $avg + $temp" | tr , . | bc)
else
okqty=$(echo "scale=0; $okqty+1" | bc -l)
avg=$(echo "scale=4; $avg + $temp" | tr , . | bc)
fi
done
avg=$(echo $avg/$count | bc )
if [[ "$criticalqty" -ge "1" ]]; then
echo "critical: $criticalqty $crt Average temperature= $avg $unit|Average-HD-temp=$avg$unit;$warning;$critical;$var2;$var3"
exit 2
elif [[ "$warningqty" -ge "1" ]]; then
echo "warning: $warningqty $wrn Average temperature= $avg $unit|Average-HD-temp=$avg$unit;$warning;$critical;$var2;$var3"
exit 1
else
echo "OK: $okqty HD´s Average temperature= $avg $unit|Average-HD-temp=$avg$unit;$warning;$critical;$var2;$var3"
exit 0
fi
# Free mem
elif [[ "$check" == "mem" ]]; then
total=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.2.0 | awk '{print $4 $5}' | sed 's/.\(.*\)...../\1/')
used=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.3.0 | awk '{print $4 $5}' | sed 's/.\(.*\)...../\1/')
perc=$(echo "scale=0; 100-($used*100)/$total" | bc -l)
unit=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.2.0 | awk '{print $5}' | sed 's/.*\(.B\).*/\1/')
free=$(echo "scale=0; $total-$used" | bc -l)
output="Memory Total=$total$unit used=$used$unit free:$free$unit|Memory-usage=$perc%;$warning;$critical;0;100"
if [[ $perc -ge $critical ]]; then
echo "critical: "$output
exit 2
elif [[ $perc -ge $warning ]]; then
echo "warning: "$output
exit 1
else
echo "OK: "$output
exit 0
fi
# Volumestatus
elif [[ "$check" == "volstatus" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.16.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
status=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.17.1.6.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
if [[ $status == "Ready" ]]; then
okqty=$(echo "scale=0; okqty+1" |bc -l)
elif [[ $status == "Rebuilding..." ]]; then
warningqty=$(echo "scale=0; $warningqty+1" | bc -l)
else
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
fi
capacity=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.17.1.4.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
free=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.17.1.5.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
unit=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.17.1.4.$c | awk '{print $5}' | sed 's/.*\(.B\).*/\1/')
unit2=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.17.1.5.$c | awk '{print $5}' | sed 's/.*\(.B\).*/\1/')
if [[ "$unit" == "TB" ]]; then
factor=$(echo "scale=0; 1000" | bc -l)
elif [[ "$unit" == "GB" ]]; then
factor=$(echo "scale=0; 100" | bc -l)
else
factor=$(echo "scale=0; 1" | bc -l)
fi
if [[ "$unit2" == "TB" ]]; then
factor2=$(echo "scale=0; 1000" | bc -l)
elif [[ "$unit2" == "GB" ]]; then
factor2=$(echo "scale=0; 100" | bc -l)
else
factor2=$(echo "scale=0; 1" | bc -l)
fi
capacitybytes=$(echo "scale=0; $capacity*$factor" | bc -l)
freebytes=$(echo "scale=0; $free*$factor2" | bc -l)
usedbytes=$(echo "scale=0; $capacitybytes-$freebytes" | bc -l)
used=$(echo "scale=0; $usedbytes/$factor" | bc -l)
usedperc=$(echo "scale=0; $usedbytes*100/$capacitybytes" | bc -l)
freeperc=$(echo "scale=0; $freebytes*100/$capacitybytes" | bc -l)
if [[ $usedperc -ge $critical ]]; then
crt="$usedperc"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
elif [[ $perc -ge $warning ]]; then
wrn="$usedperc"
warningqty=$(echo "scale=0; $warningqty+1" | bc -l)
fi
if [[ $c -lt $count ]]; then
output="$output Volume-$c $status, Total=$capacity $unit, Used=$used $unit, Free=$free $unit2, "
else
output="$output Volume-$c $status, Total=$capacity $unit, Used=$used $unit, Free=$free $unit2"
fi
done
if [[ $criticalqty -ge 1 ]]; then
echo "critical: $criticalqty $crt, $output|Used=$usedperc%;$warning;$critical;0;100"
exit 2
elif [[ $warningqty -ge 1 ]]; then
echo "warning: $warningqty $wrn, $output|Used=$usedperc%;$warning;$critical;0;100"
exit 1
else
echo "OK: $okqty Volumes, $output|Used=$usedperc%;$warning;$critical;0;100"
exit 0
fi
# Fan
elif [[ "$check" == "fan" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.14.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
speed=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.15.1.3.$c | awk '{print $4}' | cut -c 2-5 )
if [[ $speed -le 5000 ]]; then
okqty=$(echo "scale=0; $okqty+1" | bc -l)
avg=$(echo "scale=4; $avg + $speed" | tr , . | bc)
else
crt="$crt| HD-$c $speed RPM"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
avg=$(echo "scale=4; $avg + $speed" | tr , . | bc)
fi
done
avg=$(echo $avg/$count | bc )
if [[ "$criticalqty" -ge "1" ]]; then
echo "CRITICAL: $criticalqty Average Speed=$avg RPM"
exit 2
else
echo "OK Fans $okqty Average Speed=$avg RPM|Average-Speed=$avg RPM;4800;5200"
exit 0
fi
# HD Status
elif [[ "$check" == "hdstatus" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.10.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
status=$($mysnmpcheck 1.3.6.1.4.1.24681.1.2.11.1.7.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
if [[ $status == "GOOD" ]]; then
okqty=$(echo "scale=0; $okqty+1" | bc -l)
elif [[ "$status" == "--" ]]; then
niu=$(echo "scale=0; $niu+1" | bc -l)
else
crt=" Disk ${c}"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
fi
done
if [[ "$criticalqty" -ge "1" ]]; then
echo "CRITICAL: ${crt}"
exit 2
else
echo "OK: Online Disk $okqty, HD status = GOOD, Free Slot $niu"
exit 0
fi
# Cachedisstatus
elif [[ "$check" == "cachediskstatus" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.1.1.6.1.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
status=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.1.1.6.2.1.4.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
if [[ "$status" -eq "0" ]]; then
okqty=$(echo "scale=0; $okqty+1" | bc -l)
else
crt="Cachedisk NOK $c"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
fi
done
if [[ "$criticalqty" -ge "1" ]]; then
echo "CRITICAL: ${criticalqty}"
exit 2
else
echo "OK: Cachedisk $okqty "
exit 0
fi
# LUN Status
elif [[ "$check" == "lunstatus" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.2.1.10.1.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
status=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.2.1.10.2.1.5.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
if [[ $status == "Enabled" ]]; then
okqty=$(echo "scale=0; $okqty+1" | bc -l)
else
crt=" LUN NOK ${c}"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
fi
done
if [[ "$criticalqty" -ge "1" ]]; then
echo "CRITICAL: ${criticalqty}"
exit 2
else
echo "OK: LUN´s $okqty"
exit 0
fi
# raid Status
elif [[ "$check" == "raidstatus" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.1.2.1.1.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
status=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.1.2.1.2.1.5.$c | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
if [[ $status == "Ready" ]]; then
okqty=$(echo "scale=0; $okqty+1" | bc -l)
else
crt=" Raid NOK $c"
fi
done
if [[ "$criticalqty" -ge "1" ]]; then
echo "CRITICAL: $crt"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
exit 2
else
echo "OK: Raid $okqty Ready"
exit 0
fi
# Power stuply status
elif [[ "$check" == "powerstatus" ]]; then
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.1.1.3.1.0 | awk '{print $4}')
for (( c=1; c<=$count; c++ ))
do
status=$($mysnmpcheck .1.3.6.1.4.1.24681.1.4.1.1.1.1.3.2.1.4.$c | awk '{print $4}')
if [[ "$status" -eq "0" ]]; then
okqty=$(echo "scale=0; $okqty+1" | bc -l)
else
crt="Powersupply NOK $c"
criticalqty=$(echo "scale=0; $criticalqty+1" | bc -l)
fi
done
if [[ "$criticalqty" -ge "1" ]]; then
echo "CRITICAL: ${criticalqty}"
exit 2
else
echo "OK: Powersupply $okqty "
exit 0
fi
#Model
elif [[ "$check" == "sysinfo" ]]; then
model=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.12.0 | awk '{print $4}' | sed 's/^"\(.*\).$/\1/')
hdnum=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.10.0 | awk '{print $4}')
count=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.16.0 | awk '{print $4}')
name=$($mysnmpcheck .1.3.6.1.4.1.24681.1.2.13.0 | awk '{print $4}' | sed 's/^"\(.*\)$/\1/')
firmware=$($mysnmpcheck .1.3.6.1.2.1.47.1.1.1.1.9.1 | awk '{print $4}' | sed 's/^"\(.*\)$/\1/')
netuptime=$($mysnmpcheck .1.3.6.1.2.1.1.3.0 | awk '{print $5, $6, $7, $8}')
sysuptime=$($mysnmpcheck .1.3.6.1.2.1.25.1.1.0 | awk '{print $5, $6, $7, $8}')
echo NAS $name, Model $model, Firmware $firmware, Max HD number $hdnum, No. volume $count, system Uptime $sysuptime, Network Uptime $netuptime
exit 0
#statements
#
else
echo -e "\nUnknown check!" && exit "3"
fi
exit 0
Eigene Icinga-Constants erstellen.
vi /opt/docker-compose-icinga/icinga2.conf.d/constants.conf
Inhalt:
# My Custom Plugins
const CustomPluginDir = "custom_data/custom.conf.d/my-plugins/"
Nun noch den Icinga stack neu starten.
cd /opt/docker-compose-icinga
docker compose restart
Jetzt kann der neu definierte Check im Director normal verwendet werden.
- neues Kommando erstellen
- Reiter Kommando
- **Kommandotyp**: ''Plugin Check Command''
- **Kommandoname**: ''check_qnap2''
- **Kommando**: ''/custom_data/custom.conf.d/my-plugins/check_qnap2.sh''
- Reiter Arguments
- Argument "-H"
- **Argumentname**: ''-H''
- **Beschreibung**: ''Hostaddress''
- **Werttyp**: ''Zeichenkette''
- **Wert**: ''$qnap_address$''
- **Position**: ''0''
- **Bedingungsformat**: ''Icinga-DSL''
- **Benötigt**: ''Ja''
- Argument "-C"
- **Argumentname**: ''-C''
- **Beschreibung**: ''Community''
- **Werttyp**: ''Zeichenkette''
- **Wert**: ''$qnap_community$''
- **Position**: ''1''
- **Bedingungsformat**: ''Icinga-DSL''
- **Benötigt**: ''Ja''
- Argument "-a"
- **Argumentname**: ''-a''
- **Beschreibung**: ''Argument''
- **Werttyp**: ''Zeichenkette''
- **Wert**: ''$qnap_argument$''
- **Position**: ''1''
- **Bedingungsformat**: ''Icinga-DSL''
- **Benötigt**: ''Ja''
- Neue Datenfelder anlegen
- Datenfeld "qnap_address"
- **Feldname**: ''qnap_address''
- **Beschriftung**: ''qnap_address''
- **Datentyp**: ''String''
- **Sichtbarkeit**: ''Sichtbar''
- Datenfeld "qnap_community"
- **Feldname**: ''qnap_community''
- **Beschriftung**: ''qnap_community''
- **Datentyp**: ''String''
- **Sichtbarkeit**: ''Versteckt''
- Datenfeld "qnap_argument"
- **Feldname**: ''qnap_argument''
- **Beschriftung**: ''qnap_argument''
- **Datentyp**: ''String''
- **Sichtbarkeit**: ''Sichtbar''
- neue Service Vorlage erstellen
- hier das Check-Kommando "check_qnap2" einfügen
- Reiter "Felder"
- hier die Felder "qnap_address" und "qnap_argument" als Pflichtfelder hinzufügen
- Reiter "Service"
- das Feld "qnap_address" erhält den Wert "$host.address$"
- neue Host Vorlage erstellen
- hier das Feld "qnap_community" hinzufügen
- neuen Service, z.B. für CpuLoad, anlegen
- **Importe**: die Service Vorlage die zuvor angelegt wurde
- **Host**: die Host Vorlage die zuvor angelegt wurde
- **qnap_argument**: ''cpuload''
===== Notifications =====
Damit Icinga Benachrichtungen per Mail senden kann muss man sich eine ''msmtprc'' Datei erstellt werden.
Diese steuert den lokalen Mailbefehl ''msmtp''.
cd /opt/docker-compose-icinga/
mkdir -p etc_data/msmtp/
vi etc_data/msmtp/msmtprc
Hier diesen Inhalt einfügen und nach belieben anpassen.
# Set default values: use the mail submission port 587, and always use TLS.
# On this port, TLS is activated via STARTTLS.
defaults
tls on
#tls_starttls on
tls_trust_file /etc/ssl/certs/ca-certificates.crt
logfile /var/log/msmtp.log
#aliases /etc/aliases
# Define a mail account
account
# Host name of the SMTP server
host
port
tls_starttls
# Envelope-from address
from
# Authentication
auth on
user
#password
passwordeval gpg2 --no-tty -q -d /etc/.msmtp-cred.gpg
account default:
Dann erstellt man sich die verschlüsslete Datei mit dem Passwort.
vi etc_data/msmtp/.msmtp-cred.txt
Hier das Passwort einfügen und danach verschlüsseln.
gpg -c .msmtp-cred.txt
Die Passphrase merken, wird im Container jedes mal wenn er neu gestartet wurde abgefragt.
Möchte man gpg nicht verwenden, dann einfach wie oben beschrieben das Passwort als Plaintext einfügen.
Den Inhalt kann man so prüfen.
gpg -d --no-tty -q .msmtp-cred.txt.gpg
Die beiden Dateien ''msmtp'' und ''.msmtp-cred.php'' müssen noch in den "icinga2" container eingebunden werden.
Dazu in der "docker-compose.yml" unter dem Service "icinga2" folgende Volumes hinzufügen.
- ./etc_data/msmtp/msmtprc:/etc/msmtprc:ro
- ./etc_data/msmtp/.msmtp-cred.txt.gpg:/etc/.msmtp-cred.txt.gpg:ro
Jetzt noch die Konfiguration bekannt machen.
docker compose stop && docker compose up -d
Die Grundlage zum Senden von Mails ist nun vorhanden.
Man kann im "icinga2" container das senden mit diesem Befehl testen.
echo "Irgend ein Text" | mail -a "From: --debug-level=all
Jetzt noch IcingaWeb konfigurieren.
- Felder erstellen
- notification_from
- **Datentyp**: String
- Zeitperiode erstellen
- im Reiter "Bereiche" jeden Tag den man benachrichtigt werden will definieren
- Benutzer erstellen
- **Zeitraum**: den vorhin definierten
- **Benachrichtigungen senden**: ja
- **E-Mail**: Mailadresse des Benutzers
- **Zustände**: benötigte wählen
- **Änderungsstypen**: benötigte wählen
- Benachrichtigungsvorlage für Hosts und Services erstellen
- **Felder hinzufügen**: notification_from
- **Benutzer**: den erstellten Benutzer wählen
- **Benachrichtigungskommando**: mail-host-notification bzw. mail-service-notification
- **Benachrichtigungsintervall**: wie oft sollen benachrichtungen bei Ereignissen wiederholt werden
- **Zeitraum**: den zuvor erstellten
- **notification_from**: Absender Mailadresse
- **Zustände**: benötigte wählen
- **Änderungsstypen**: benötigte wählen
- Benachrichtigung für Hosts und Services erstellen
- **Importe**: zuvor erstellte Vorlage für Host/Service
- **Benutzer**: zuvor erstellten Benutzer
- **Anwenden auf**: Hosts bzw. Services
- **Zuweisen wo**: 1. Textfeld: "host.enable_notifications" 2. Operatorfeld: "is true (or set)"
Wenn nun noch der Host oder Service die Benachrichtigungen aktiviert hat, werden Mails gesendet.
Man kann in IcingaWeb an einem Host oder Server eine Benutzerdefinierte Benachrichtigung senden und dann im Log des Containers das senden der Mail sehen.
Dazu müssen Benutzerdefinierte Benachrichtigungen oben überall als Änderungsstypen angegeben werden.
Die Logs des Containers kann man sich so anzeigen.
cd /opt/docker-compose-icinga
docker compose logs -f icinga2
===== Graphite =====
Mit Graphite kann man Performancedaten der einzelnen Checks grafisch darstellen.
Zum einbinden von Graphite folgendes tun.
- Docker Container erstellen cd /opt/docker-compose-icinga
vi docker-compose.yml
- hier beim Service "icingaweb" diese Zeile wie folgt anpassen icingaweb.enabledModules: director, icingadb, incubator, graphite
- danach folgendes unter den letzten Service einfügen graphite:
container_name: graphite
image: graphiteapp/graphite-statsd
restart: always
ports:
- "50080:80"
- "52003-52004:2003-2004"
- "52023-52024:2023-2024"
- "58125:8125/udp"
- "58126:8126"
hostname: graphite
volumes:
#- ./backup:/opt/backup
#- ./conf/graphite/conf:/opt/graphite/conf
- ./graphite/graphite/storage:/opt/graphite/storage
#- ./conf/webapp/graphite/functions/custom:/opt/graphite/webapp/graphite/functions/custom
#- ./conf/nginx:/etc/nginx
#- ./conf/statsd/config:/opt/statsd/config
#- ./conf/logrotate.d:/etc/logrotate.d
#- ./var/log:/var/log
#- ./var/lib/redis:/var/lib/redis
environment:
- GRAPHITE_TIME_ZONE=Europe/Berlin
- GRAPHITE_DATE_FORMAT=%m/%d
- COLLECTD=1
- Volumeordner für Graphite erstellen mkdir -p ./graphite/graphite/storage
- Icinga Konfiguration zum senden von Performancedaten erstellen mkdir -p ./icinga2.conf.d/features-enabled
- hier die Datei graphite.conf mit folgendem Inhalt erstellen /**
* The GraphiteWriter type writes check result metrics and
* performance data to a graphite tcp socket.
*/
object GraphiteWriter "graphite" {
host = "graphite"
port = 2003
}
- Graphite Container starten docker compose stop && docker compose up -d
- ggf. in IcingaWeb unter Einstellungen (Zahnrad) -> "Modul" das Modul "graphite" einschalten
- im Reiter "Backend" unter "Graphite Web URL" die URL "http://graphite:80/" einfügen
- In der Ansicht eines Hosts oder Service werden nun die Graphen angezeigt, vorausgesetzt die Performancedaten sind in den jew. Icinga-Objekten eingeschaltet
- Über die URL "http://:50080/" kann man direkt auf die Graphite Webseite zugreifen