9 Tīmekļa uzraudzība
Pārskats
Ar Zabbix varat pārbaudīt vairākus tīmekļa vietņu pieejamības aspektus.
Lai veiktu tīmekļa uzraudzību, Zabbix serverim sākotnēji jābūt konfigurētam ar cURL (libcurl) atbalstu.
Lai aktivizētu tīmekļa uzraudzību, jums jādefinē tīmekļa scenāriji. Tīmekļa scenārijs sastāv no viena vai vairākiem HTTP pieprasījumiem jeb "soļiem". Soļus periodiski izpilda Zabbix serveris iepriekš noteiktā secībā. Ja hosts tiek uzraudzēts ar starpniekserveri, soļus izpilda starpniekserveris.
Tīmekļa scenāriji tiek piesaistīti hostiem/veidnēm tāpat kā vienumi, trigeri utt. Tas nozīmē, ka tīmekļa scenārijus var izveidot arī veidnes līmenī un pēc tam vienā reizē piemērot vairākiem hostiem.
Jebkurā tīmekļa scenārijā tiek apkopota šāda informācija:
- vidējais lejupielādes ātrums sekundē visiem visa scenārija soļiem
- neveiksmīgā soļa numurs
- pēdējais kļūdas ziņojums
Jebkurā tīmekļa scenārija solī tiek apkopota šāda informācija:
- lejupielādes ātrums sekundē
- atbildes laiks
- atbildes kods
Plašāku informāciju skatiet sadaļā web monitoring items.
No tīmekļa scenāriju izpildes savāktie dati tiek glabāti datubāzē. Šie dati tiek automātiski izmantoti diagrammām, trigeriem un paziņojumiem.
Zabbix var arī pārbaudīt, vai iegūtā HTML lapa satur iepriekš noteiktu virkni. Tas var izpildīt simulētu pieteikšanos un sekot simulētu peles klikšķu ceļam lapā.
Zabbix tīmekļa uzraudzība atbalsta gan HTTP, gan HTTPS. Palaižot tīmekļa scenāriju, Zabbix pēc izvēles sekos pāradresācijām (skatiet tālāk opciju Sekot pāradresācijām). Maksimālais pāradresāciju skaits ir fiksēts uz 10 (izmantojot cURL opciju CURLOPT_MAXREDIRS). Visas sīkdatnes tiek saglabātas viena scenārija izpildes laikā.
Tīmekļa scenārija konfigurēšana
Lai konfigurētu tīmekļa scenāriju:
- Dodieties uz: Datu vākšana → Hosts (vai Veidnes)
- Rindā ar hostu/veidni noklikšķiniet uz Web
- Labajā pusē noklikšķiniet uz Izveidot tīmekļa scenāriju (vai uz scenārija nosaukuma, lai rediģētu esošu scenāriju)
- Formā ievadiet scenārija parametrus
Cilne Scenārijs ļauj konfigurēt tīmekļa scenārija vispārīgos parametrus.

Visi obligātie ievades lauki ir atzīmēti ar sarkanu zvaigznīti.
Scenārija parametri:
| Parameter | Description |
|---|---|
| Name | Unikāls scenārija nosaukums. Tiek atbalstīti lietotāja makrosi. Piezīme: ja tiek izmantoti lietotāja makrosi, šie makrosi paliks neatrisināti tīmekļa uzraudzības vienums nosaukumos. |
| Update interval | Cik bieži scenārijs tiks izpildīts. Tiek atbalstīti laika sufiksi, piemēram, 30s, 1m, 2h, 1d. Tiek atbalstīti lietotāja makrosi. Piezīme: ja tiek izmantots lietotāja makross un tā vērtība tiek mainīta (piem., 5m → 30s), nākamā pārbaude tiks izpildīta atbilstoši iepriekšējai vērtībai (ar dotajiem piemēriem - vēlāk nākotnē). Jauni tīmekļa scenāriji tiks pārbaudīti 60 sekunžu laikā pēc to izveides. |
| Attempts | Mēģinājumu skaits tīmekļa scenārija soļu izpildei. Tīkla problēmu gadījumā (noildze, savienojuma trūkums utt.) Zabbix var atkārtot soļa izpildi vairākas reizes. Norādītais skaitlis vienādi ietekmēs katru scenārija soli. Var norādīt līdz 10 mēģinājumiem, noklusējuma vērtība ir 1. Piezīme: Zabbix neatkārtos soli nepareiza atbildes koda vai prasītās virknes neatbilstības dēļ. |
| Agent | Atlasiet klienta aģentu. Zabbix izliksies par atlasīto pārlūkprogrammu. Tas ir noderīgi, ja vietne dažādām pārlūkprogrammām atgriež atšķirīgu saturu. Šajā laukā var izmantot lietotāja makrosus. |
| HTTP proxy | Varat norādīt izmantojamo HTTP starpniekserveri, izmantojot formātu [protocol://][username[:password]@]proxy.example.com[:port].Tas iestata cURL opciju CURLOPT_PROXY. Neobligāto prefiksu protocol:// var izmantot, lai norādītu alternatīvus starpniekservera protokolus (protokola prefiksa atbalsts tika pievienots cURL 7.21.7 versijā). Ja protokols nav norādīts, starpniekserveris tiks uzskatīts par HTTP starpniekserveri.Pēc noklusējuma tiks izmantots 1080 ports. Ja tas ir norādīts, starpniekserveris pārrakstīs ar starpniekserveri saistītās vides mainīgās, piemēram, http_proxy, HTTPS_PROXY. Ja nav norādīts, starpniekserveris nepārrakstīs ar starpniekserveri saistītās vides mainīgās. Ievadītā vērtība tiek nodota "tā, kā ir", bez jebkādas pārbaudes. Varat arī ievadīt SOCKS starpniekservera adresi. Ja norādīsiet nepareizu protokolu, savienojums neizdosies un vienums kļūs neatbalstīts. Piezīme: ar HTTP starpniekserveri tiek atbalstīta tikai vienkārša autentifikācija. Šajā laukā var izmantot lietotāja makrosus. |
| Variables | Mainīgie, kurus var izmantot scenārija soļos (URL, post mainīgie). Tiem ir šāds formāts: {macro1}=value1 {macro2}=value2 {macro3}=regex:<regular expression> {macro4}=jsonpath:<jsonpath> {macro5}=xmlxpath:<xmlxpath> {macro6}={{macro}.function()} (skatiet makro funkcijas) Piemēram: {username}=Alexei {password}=kj3h5kJ34bd {hostid}=regex:hostid is ([0-9]+) {url}=jsonpath:$.host_url {status}=xmlxpath://host/response/status {newvar}={{myvar}.btoa()} Pēc tam makrosus var izmantot soļos kā {username}, {password}, {hostid} utt. Zabbix tos automātiski aizstās ar faktiskajām vērtībām. Ņemiet vērā, ka mainīgajiem ar regex: ir nepieciešams viens solis, lai iegūtu regulārās izteiksmes vērtību, tāpēc iegūto vērtību var piemērot tikai nākamajam solim.Ja vērtības daļa sākas ar regex:, tad daļa aiz tās tiek uzskatīta par regulāro izteiksmi, kas meklē tīmekļa lapā un, ja tiek atrasta, saglabā atbilstību mainīgajā. Jābūt vismaz vienai apakšgrupai, lai varētu iegūt atbilstošo vērtību.Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. Mainīgie tiek automātiski URL kodēti, ja tos izmanto vaicājuma laukos vai formas datos post mainīgajiem, taču tie ir jāURL kodē manuāli, ja tos izmanto raw post vai tieši URL. |
| Headers | HTTP galvenes tiek izmantotas pieprasījuma veikšanas laikā. Var izmantot noklusējuma un pielāgotās galvenes. Galvenes tiks piešķirtas, izmantojot noklusējuma iestatījumus atkarībā no scenārija līmenī nolaižamajā sarakstā atlasītā aģenta tipa, un tās tiks piemērotas visiem soļiem, ja vien tās nav pielāgotas soļa līmenī. Jāņem vērā, ka galvenes definēšana soļa līmenī automātiski atmet visas iepriekš definētās galvenes, izņemot noklusējuma galveni, kas tiek piešķirta, scenārija līmenī nolaižamajā sarakstā atlasot 'User-Agent'. Tomēr pat noklusējuma galveni 'User-Agent' var pārrakstīt, norādot to soļa līmenī. Lai noņemtu galveni scenārija līmenī, galvenei jāpiešķir nosaukums un soļa līmenī jānorāda bez vērtības. Galvenes jāuzskaita, izmantojot to pašu sintaksi, kāda tām būtu HTTP protokolā, pēc izvēles izmantojot dažas papildu iespējas, ko atbalsta cURL opcija CURLOPT_HTTPHEADER. Piemēram: Accept-Charset=utf-8 Accept-Language=en-US Content-Type=application/xml; charset=utf-8 Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. |
| Enabled | Scenārijs ir aktīvs, ja šī izvēles rūtiņa ir atzīmēta; pretējā gadījumā - atspējots. |
Ņemiet vērā, ka, rediģējot esošu scenāriju, formā ir pieejamas divas papildu pogas:
![]() |
Izveidot vēl vienu scenāriju, pamatojoties uz esošā scenārija īpašībām. |
![]() |
Dzēst scenārija vēstures un tendenču datus. Tas liks serverim nekavējoties izpildīt scenāriju pēc datu dzēšanas. |
Ja HTTP proxy lauks ir atstāts tukšs, cits veids, kā izmantot HTTP starpniekserveri, ir iestatīt ar starpniekserveri saistītās vides mainīgās.
HTTP pārbaudēm - iestatiet http_proxy vides mainīgo Zabbix servera lietotājam. Piemēram,
http_proxy=http://proxy_ip:proxy_port.
HTTPS pārbaudēm - iestatiet HTTPS_PROXY vides mainīgo. Piemēram, HTTPS_PROXY=http://proxy_ip:proxy_port. Plašāka informācija pieejama, izpildot čaulas komandu: # man curl.
Cilne Soļi ļauj konfigurēt tīmekļa scenārija soļus. Lai pievienotu tīmekļa scenārija soli, blokā Soļi noklikšķiniet uz Pievienot.

Slepenus lietotāja makrosus URL nedrīkst izmantot, jo tie tiks atrisināti kā "******".
Soļu konfigurēšana

Soļa parametri:
| Parametrs | Apraksts |
|---|---|
| Name | Unikāls soļa nosaukums. Tiek atbalstīti lietotāja makrosi. Ņemiet vērā, ka, ja tiek izmantoti lietotāja makrosi, šie makrosi paliks neatrisināti tīmekļa uzraudzības vienumu nosaukumos. |
| URL | URL, ar kuru izveidot savienojumu un iegūt datus. Piemēram: https://www.example.com http://www.example.com/download Domēna nosaukumus var norādīt Unicode rakstzīmēs. Izpildot tīmekļa scenārija soli, tie tiek automātiski pārveidoti no punycode uz ASCII. Pogu Parse var izmantot, lai no URL atdalītu neobligātos vaicājuma laukus (piemēram, ?name=Admin&password=mypassword), pārvietojot atribūtus un vērtības uz Query fields automātiskai URL kodēšanai. URL var izmantot mainīgos, izmantojot sintaksi {macro}. Mainīgos var URL kodēt manuāli, izmantojot sintaksi {{macro}.urlencode()}. Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. Ierobežots līdz 2048 rakstzīmēm. |
| Query fields | HTTP GET mainīgie URL adresei. Norādīti kā atribūtu un vērtību pāri. Vērtības tiek automātiski URL kodētas. Vērtības no scenārija mainīgajiem, lietotāja makrosiem vai {HOST.*} makrosiem tiek atrisinātas un pēc tam automātiski URL kodētas. Izmantojot sintaksi {{macro}.urlencode()}, tās tiks URL kodētas divreiz. Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. |
| Post | HTTP POST mainīgie. Režīmā Form data tie tiek norādīti kā atribūtu un vērtību pāri. Vērtības tiek automātiski URL kodētas. Vērtības no scenārija mainīgajiem, lietotāja makrosiem vai {HOST.*} makrosiem tiek atrisinātas un pēc tam automātiski URL kodētas. Režīmā Raw data atribūti/vērtības tiek parādīti vienā rindā un savienoti ar simbolu &. Neapstrādātas vērtības var URL kodēt/dekodēt manuāli, izmantojot sintaksi {{macro}.urlencode()} vai {{macro}.urldecode()}. Piemēram: id=2345&userid={user} Ja {user} ir definēts kā tīmekļa scenārija mainīgais, izpildot soli tas tiks aizstāts ar savu vērtību. Ja vēlaties mainīgo URL kodēt, aizstājiet {user} ar {{user}.urlencode()}. Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. |
| Variables | Soļa līmeņa mainīgie, kurus var izmantot GET un POST funkcijām. Norādīti kā atribūtu un vērtību pāri. Soļa līmeņa mainīgie pārraksta scenārija līmeņa mainīgos vai iepriekšējā soļa mainīgos. Tomēr soļa līmeņa mainīgā vērtība ietekmē tikai nākamo soli (nevis pašreizējo soli). Tiem ir šāds formāts: {macro}=value {macro}=regex:<regular expression> Papildinformāciju skatiet mainīgo aprakstā scenārija līmenī. Mainīgie tiek automātiski URL kodēti, ja tos izmanto vaicājuma laukos vai formas datos POST mainīgajiem, taču tie ir manuāli URL jākodē, ja tiek izmantoti neapstrādātā POST vai tieši URL. |
| Headers | Pielāgotas HTTP galvenes, kas tiks nosūtītas, izpildot pieprasījumu. Norādītas kā atribūtu un vērtību pāri. Soļa līmenī definēta galvene tiks izmantota konkrētajam solim. Jāņem vērā, ka galvenes definēšana soļa līmenī automātiski atmet visas iepriekš definētās galvenes, izņemot noklusējuma galveni, kas tiek piešķirta, scenārija līmenī nolaižamajā sarakstā izvēloties 'User-Agent'. Tomēr pat noklusējuma galveni 'User-Agent' var pārrakstīt, to norādot soļa līmenī. Piemēram, piešķirot galvenei nosaukumu, bet nenorādot vērtību, scenārija līmeņa noklusējuma galvene tiks atcelta. Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. Tas iestata CURLOPT_HTTPHEADER cURL opciju. |
| Follow redirects | Atzīmējiet izvēles rūtiņu, lai sekotu HTTP pāradresācijām. Tas iestata CURLOPT_FOLLOWLOCATION cURL opciju. |
| Retrieve mode | Atlasiet iegūšanas režīmu: Body - iegūt tikai HTTP atbildes pamattekstu Headers - iegūt tikai HTTP atbildes galvenes Body and headers - iegūt HTTP atbildes pamattekstu un galvenes |
| Timeout | Zabbix URL apstrādei netērēs vairāk par iestatīto laiku (no vienas sekundes līdz maksimāli 1 stundai). Faktiski šis parametrs nosaka maksimālo laiku savienojuma izveidei ar URL un maksimālo laiku HTTP pieprasījuma izpildei. Tādēļ Zabbix šim solim netērēs vairāk par 2 x Timeout sekundēm. Tiek atbalstīti laika sufiksi, piemēram, 30s, 1m, 1h. Tiek atbalstīti lietotāja makrosi. |
| Required string | Obligāts regulārās izteiksmes raksts. Ja vien iegūtais saturs (HTML) neatbilst obligātajam rakstam, solis neizdosies. Ja lauks ir tukšs, obligātās virknes pārbaude netiek veikta. Piemēram: Zabbix sākumlapa Welcome.*admin Piezīme: Šajā laukā netiek atbalstīta atsauce uz regulārajām izteiksmēm, kas izveidotas Zabbix lietotāja saskarnē. Tiek atbalstīti lietotāja makrosi un {HOST.*} makrosi. |
| Required status codes | Sagaidāmo HTTP statusa kodu saraksts. Ja Zabbix saņem kodu, kas nav sarakstā, solis neizdosies. Ja lauks ir tukšs, statusa kodu pārbaude netiek veikta. Piemēram: 200,201,210-299 Tiek atbalstīti lietotāja makrosi. |
Jebkādas izmaiņas tīmekļa scenārija soļos tiks saglabātas tikai tad, kad tiks saglabāts viss scenārijs.
Skatiet arī reālu piemēru, kā var konfigurēt tīmekļa uzraudzības soļus.
Birku konfigurēšana
Cilne Tags ļauj definēt scenārija līmeņa birkas.

Birku izmantošana ļauj filtrēt tīmekļa scenārijus un tīmekļa uzraudzības vienumus.
Autentifikācijas konfigurēšana
Cilne Authentication ļauj konfigurēt scenārija autentifikācijas opcijas. Zaļš punkts blakus cilnes nosaukumam norāda, ka ir iespējots kāds HTTP autentifikācijas veids.

Autentifikācijas parametri:
| Parametrs | Apraksts |
|---|---|
| HTTP authentication | Izvēlieties autentifikācijas opciju: None - autentifikācija netiek izmantota; Basic - tiek izmantota pamata autentifikācija; NTLM - tiek izmantota NTLM (Windows NT LAN Manager) autentifikācija; Kerberos - tiek izmantota Kerberos autentifikācija (skatiet arī: Configuring Kerberos with Zabbix); Digest - tiek izmantota Digest autentifikācija. |
| User | Ievadiet lietotājvārdu (līdz 255 rakstzīmēm). Šis lauks ir pieejams, ja HTTP authentication ir iestatīts uz Basic, NTLM, Kerberos vai Digest. Tiek atbalstīti lietotāja makrosi. |
| Password | Ievadiet lietotāja paroli (līdz 255 rakstzīmēm). Šis lauks ir pieejams, ja HTTP authentication ir iestatīts uz Basic, NTLM, Kerberos vai Digest. Tiek atbalstīti lietotāja makrosi. |
| SSL verify peer | Atzīmējiet izvēles rūtiņu, lai pārbaudītu tīmekļa servera SSL sertifikātu. Servera sertifikāts tiks automātiski ņemts no sistēmas sertifikātu iestādes (CA) atrašanās vietas. CA failu atrašanās vietu varat pārrakstīt, izmantojot Zabbix serveris vai starpniekserveris konfigurācijas parametru SSLCALocation. Tas iestata CURLOPT_SSL_VERIFYPEER cURL opciju. |
| SSL verify host | Atzīmējiet izvēles rūtiņu, lai pārbaudītu, vai tīmekļa servera sertifikāta lauks Common Name vai lauks Subject Alternate Name atbilst. Tas iestata CURLOPT_SSL_VERIFYHOST cURL opciju. |
| SSL certificate file | SSL sertifikāta faila nosaukums, kas tiek izmantots klienta autentifikācijai. Sertifikāta failam jābūt PEM1 formātā. Ja sertifikāta fails satur arī privāto atslēgu, atstājiet lauku SSL key file tukšu. Ja atslēga ir šifrēta, norādiet paroli laukā SSL key password. Direktoriju, kurā atrodas šis fails, nosaka Zabbix serveris vai starpniekserveris konfigurācijas parametrs SSLCertLocation. Šajā laukā var izmantot HOST.* makrosus un lietotāja makrosus.Tas iestata CURLOPT_SSLCERT cURL opciju. |
| SSL key file | SSL privātās atslēgas faila nosaukums, kas tiek izmantots klienta autentifikācijai. Privātās atslēgas failam jābūt PEM1 formātā. Direktoriju, kurā atrodas šis fails, nosaka Zabbix serveris vai starpniekserveris konfigurācijas parametrs SSLKeyLocation. Šajā laukā var izmantot HOST.* makrosus un lietotāja makrosus.Tas iestata CURLOPT_SSLKEY cURL opciju. |
| SSL key password | SSL privātās atslēgas faila parole. Šajā laukā var izmantot lietotāja makrosus. Tas iestata CURLOPT_KEYPASSWD cURL opciju. |
[1] Zabbix atbalsta tikai sertifikātu un privātās atslēgas failus PEM formātā. Ja jūsu sertifikāta un privātās atslēgas dati ir PKCS #12 formāta failā (parasti ar paplašinājumu *.p12 vai *.pfx), no tā varat ģenerēt PEM failu, izmantojot šādas komandas:
openssl pkcs12 -in ssl-cert.p12 -clcerts -nokeys -out ssl-cert.pem
openssl pkcs12 -in ssl-cert.p12 -nocerts -nodes -out ssl-cert.key
Zabbix serveris uztver izmaiņas sertifikātos bez restartēšanas.
Ja klienta sertifikāts un privātā atslēga ir vienā failā, vienkārši norādiet to laukā "SSL certificate file" un atstājiet lauku "SSL key file" tukšu. Sertifikātam un atslēgai joprojām jābūt PEM formātā. Sertifikāta un atslēgas apvienošana ir vienkārša:
cat client.crt client.key > client.pem
Attēlošana
Lai skatītu hostam konfigurētos tīmekļa scenārijus, dodieties uz Monitoring → Hosts, atrodiet hostu sarakstā un noklikšķiniet uz Web hipersaites pēdējā kolonnā. Noklikšķiniet uz scenārija nosaukuma, lai iegūtu detalizētu informāciju.

Tīmekļa scenāriju pārskatu var arī attēlot Dashboards sadaļā, izmantojot Web monitoring logrīku.
Pēdējie tīmekļa scenārija izpildes rezultāti ir pieejami sadaļā Monitoring → Latest data.
Paplašinātā uzraudzība
Dažreiz ir nepieciešams reģistrēt saņemtās HTML lapas saturu.
Tas ir īpaši noderīgi, ja kāds tīmekļa scenārija solis neizdodas.
Šim nolūkam kalpo 5. atkļūdošanas līmenis (izsekošana).
Šo līmeni var iestatīt serveris un starpniekserveris konfigurācijas failos vai izmantojot izpildlaika vadības opciju (-R log_level_increase="http poller,N", kur N ir procesa numurs).
Tālāk sniegtie piemēri parāda, kā var palaist paplašināto uzraudzību, ja 4. atkļūdošanas līmenis jau ir iestatīts:
# Palielināt žurnāla līmeni visiem http poller procesiem:
zabbix_server -R log_level_increase="http poller"
# Palielināt žurnāla līmeni otrajam http poller procesam:
zabbix_server -R log_level_increase="http poller,2"
Ja paplašinātā tīmekļa uzraudzība nav nepieciešama, to var apturēt, izmantojot
opciju -R log_level_decrease.

