Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
vyuka:cviceni:y36sps:semestralky:plchm1 [2009/05/21 21:59] – plchm1 | vyuka:cviceni:y36sps:semestralky:plchm1 [2009/05/27 15:20] (current) – plchm1 | ||
---|---|---|---|
Line 8: | Line 8: | ||
Schváleno 16.4.2009: Michal Medvecký | Schváleno 16.4.2009: Michal Medvecký | ||
- | ===== Zadání | + | |
+ | |||
+ | ===== Obecně | ||
+ | Hlavní router celé sítě je Debian Etch. Běží na něm dohled- Nagios a MRTG, vpnky, autorizace uživatelů, | ||
+ | |||
+ | Pro zjednodušení práce administrátorů mají jednotlivé koncové routery svůj jmenný ekvivalent. Ten je zaznamenán na firemních DNS. | ||
+ | |||
+ | Systém Nagios jsem využil jako jeden z nejlepších a nejpoužívanějších dohledových systémů. Navíc je to firemní standard, že se k monitoringu používá právě on. | ||
===== Instalace Nagiosu ===== | ===== Instalace Nagiosu ===== | ||
Line 52: | Line 59: | ||
Tím je instalace a zprovoznění Nagiosu kompletní. | Tím je instalace a zprovoznění Nagiosu kompletní. | ||
Můžu se vrhnout na konfiguraci hostů. | Můžu se vrhnout na konfiguraci hostů. | ||
+ | |||
===== Konfigurace dohledu sítě ===== | ===== Konfigurace dohledu sítě ===== | ||
Line 86: | Line 94: | ||
rm / | rm / | ||
</ | </ | ||
- | Jak názvy | + | Jak názvy |
< | < | ||
define host { | define host { | ||
Line 107: | Line 115: | ||
</ | </ | ||
Protože přibyly nové přípojné body a status mapa začala být nepřehledná, | Protože přibyly nové přípojné body a status mapa začala být nepřehledná, | ||
+ | < | ||
define host { | define host { | ||
host_name name | host_name name | ||
Line 113: | Line 122: | ||
use generic-host | use generic-host | ||
parents parent | parents parent | ||
+ | } | ||
+ | </ | ||
+ | Nyní potřebuji dát hosty do skupin, nastavit mapu a kontakty. Vytvořím pro ně konfigurační soubory. Chci je mít vytvořeny v conf.d, protože obsahují globální nastavení a tak je nechci mít někde hluboko zanořené. | ||
+ | < | ||
+ | touch / | ||
+ | </ | ||
+ | Ale tyto konfigurační soubory obsahuje už defaultní nastavení, které teď mám přesunuté do složky preconfigured (./ | ||
+ | V contact.cfg stačí změnit emailovou adresu: | ||
+ | < | ||
+ | email you@yourdomain.com | ||
+ | </ | ||
+ | V extinfo.cfg nastavuji obrázky, které se budou zobrazovat u hostů ve status map. | ||
+ | U localhostu chci, aby se mi zobrazoval tux. | ||
+ | < | ||
+ | define hostextinfo{ | ||
+ | host_name localhost | ||
+ | icon_image base/ | ||
+ | icon_image_alt base/ | ||
+ | vrml_image base/ | ||
+ | statusmap_image base/ | ||
+ | } | ||
+ | </ | ||
+ | U routerů se mi bude ukazovat obrázek nějakého zařízení: | ||
+ | < | ||
+ | define hostextinfo{ | ||
+ | host_name hsrX, | ||
+ | icon_image base/ | ||
+ | icon_image_alt base/ | ||
+ | vrml_image base/ | ||
+ | statusmap_image base/ | ||
+ | } | ||
+ | </ | ||
+ | V group.cfg sdružuji hosty do skupin. Vytvořím 5 skupin podle služeb, které na nich chci kontrolovat- all, ssh, ping, vpn, ups. | ||
+ | < | ||
+ | define hostgroup { | ||
+ | hostgroup_name | ||
+ | alias | ||
+ | members | ||
} | } | ||
- | Přes nano doplním konfiguráky. | + | define hostgroup { |
- | Pak dodělám konfiguráky pro nastavení mapy, kontaktů a skupin. | + | hostgroup_name |
- | touch contacts.cfg extinfo.cfg groups.cfg | + | alias |
- | vymazu z / | + | members |
- | do /hosts/local.cfg zkopiruju obsah host-gateway... a ./localhost... ty pak smazu, rm localhost_nagios2.cfg rm host-gateway_nagios3.cfg muzu smazat jeste smazat | + | } |
- | extinfo z hostgroups prekopiruju | + | |
- | Přes nano doplním. | + | define hostgroup { |
- | Změny konfiguračních souborů a jejich umístění musím zadat v nagios.cfg. | + | hostgroup_name |
+ | alias | ||
+ | members | ||
+ | } | ||
+ | |||
+ | define hostgroup { | ||
+ | hostgroup_name vpn | ||
+ | alias OpenVPN tunnels | ||
+ | members hsrX-vpn | ||
+ | } | ||
+ | |||
+ | define hostgroup { | ||
+ | hostgroup_name ups | ||
+ | alias APC UPS | ||
+ | members hsrX-ups | ||
+ | } | ||
+ | </ | ||
+ | Zbývá doplnit, jaké služby chci monitorovat. Jdu do adresáře | ||
+ | < | ||
+ | mv ./generic-host_nagios2.cfg ./generic-host.cfg | ||
+ | mv ./generic-service_nagios2.cfg ./ | ||
+ | mv ./services_nagios2.cfg ./services.cfg | ||
+ | mv ./ | ||
+ | </ | ||
+ | Kontrolu služeb pro jednotlivé skupiny nastavím v ./ | ||
+ | Změním hostgroup_name podle toho, jak jsem to nakonfiguroval group.cfg. Http, kterou tam mít nepotřebuji, | ||
+ | Doplním tedy: | ||
+ | < | ||
+ | define service { | ||
+ | hostgroup_name ups | ||
+ | service_description APC UPS | ||
+ | check_command ups-check | ||
+ | use generic-service | ||
+ | notification_interval 0 | ||
+ | } | ||
+ | </ | ||
+ | Pro kontrolu pingu a ssh existuje defaultní konfigurační nastavení, ale pro ups-check musím ještě doplnit příkaz, který se má spustit. Můžu použít nějakého pluginu, nebo zkusit napsat vlastní skript. UPS APC mají vlastní webové | ||
+ | <code bash> | ||
+ | # | ||
+ | ip=" | ||
+ | x=`wget -q -t 1 -T 5 http:// | ||
+ | |||
+ | if [ $? -eq 0 ]; then | ||
+ | bat=`echo $x | sed " | ||
+ | power=`echo $x | sed " | ||
+ | status=`echo $x | sed " | ||
+ | time=`echo $x | sed " | ||
+ | capa=`echo $x | sed " | ||
+ | |||
+ | echo -ne " | ||
+ | echo -ne " | ||
+ | echo -ne " | ||
+ | if [ " | ||
+ | exit 0; | ||
+ | else | ||
+ | exit 1; | ||
+ | fi | ||
+ | |||
+ | exit 0 | ||
+ | else | ||
+ | echo "UPS communication lost" | ||
+ | exit 2 | ||
+ | fi | ||
+ | </ | ||
+ | Tento skript si uložím jako ups.sh do nově vytvořeného adresáře / | ||
+ | Teď už staří se na tento skript odkázat | ||
+ | < | ||
+ | define command { | ||
+ | command_name ups-check | ||
+ | command_line / | ||
+ | } | ||
+ | </ | ||
+ | Pro to, abych mohl používat příkazy z webového rozhraní Nagiosu je potřeba v souboru / | ||
+ | < | ||
check_external_commands=1 | check_external_commands=1 | ||
- | jeste doplnim command | + | </ |
+ | Aby se mi status mapa zobrazovala jako stromová struktura, tak edituji / | ||
+ | < | ||
+ | default_statusmap_layout=3 | ||
+ | </ | ||
+ | To bude asi vše. Zkontroluji nastavení a restartuji Nagios: | ||
+ | < | ||
+ | nagios3 -v / | ||
+ | / | ||
+ | </ | ||
+ | |||
+ | ===== Závěr ===== | ||
+ | Dohledový systém (zkušební) je možné vidět zde: http:// | ||
+ | |||
+ | Během této semestrální práce jsem si vyzkoušel práci s dohledovým systémem Nagios, což mi pomohlo při laboratorních cvičeních a při mé práci. | ||
+ | |||
+ | Zkoušel jsem také konfiguraci Nagiosu pomocí nástroje Centreon, ale ten bohužel při exportu nastavení | ||
+ | |||
+ | {{: | ||
~~DISCUSSION~~ | ~~DISCUSSION~~ | ||