Erinevus lehekülje "Collectd" redaktsioonide vahel

Allikas: Kuutõrvaja
(Keerukamad kasutusjuhud)
(Keerukamad kasutusjuhud)
80. rida: 80. rida:
 
  </Plugin>
 
  </Plugin>
  
Skripti käivitamine
+
Skripti käivitamine, antud näites loeb skript kokku faile postfixi järjekorra kaustadest
  
 +
LoadPlugin exec
 
  <Plugin exec>
 
  <Plugin exec>
   Exec "nobody:nobody" "/home/collectd-T.sh"
+
   Exec "postfix:postfix" "/etc/collectd.d/collectd-postfix.sh"
 
  </Plugin>
 
  </Plugin>
 +
 +
collectd-postfix.sh
 +
 +
<source lang=bash>
 +
#!/bin/bash
 +
 +
INTERVAL=60
 +
POSTFIX_QDIR=/var/spool/postfix
 +
 +
while :; do
 +
  time=$(date +%s)
 +
  for q in incoming active deferred corrupt hold; do
 +
    count=$(find $POSTFIX_QDIR/$q -type f -print | wc -l)
 +
    eval "$q=$count"
 +
  done
 +
  echo "PUTVAL \"$HOSTNAME/postfix/postfix_queue\" interval=$INTERVAL $time:$incoming:$active:$deferred:$corrupt:$hold"
 +
  sleep $INTERVAL
 +
done
 +
</source>
  
 
https://collectd.org/wiki/index.php/Plugin:cURL/Config curli kasutamine veebit või failidest alginfo saamiseks
 
https://collectd.org/wiki/index.php/Plugin:cURL/Config curli kasutamine veebit või failidest alginfo saamiseks

Redaktsioon: 4. aprill 2016, kell 10:59

Sissejuhatus

Collectd on klient-server töövahend erinevate mõõtemeetrikute korjamiseks ja salvestamiseks. Tegemist on ühe süsteemis töötava deemoniga, mille funktsionaalsus ehk kas tegemist serveri, klienti, proxyga saavutatakse erinevate pluginate vahendusel. Samamoodi on kõik info mida süsteemist korjatakse seadistatav läbi erinevate pluginate.

Mõned lihtsad asjad mida annab collect abil koguda on nt cpu, mälu ja võrgu kohta käiv info.

Collectd deemon ise vaid kogub ja salvestab infot ning graafikute loomiseks on vaja eraldi rakendust. Collectd töövoogu iseloomustab järgnev pilt.

Collectd.png

Paigaldamine

Debianis

# apt-get install collectd

client

 LoadPlugin "cpu"       # protsessori statistika 
 LoadPlugin "memory"    # mälu
 LoadPlugin "interface" # võrguseadmed
 
 # välistame teatud võrguseadmete graafikute joonistamise, vastupidise saavutamiseks IgnoreSelected false                                                                              
 <Plugin interface>
 Interface lo
 Interface sit0
 IgnoreSelected true
 </Plugin>
 
 LoadPlugin "network"
 # saadame kõik info enda collectd serverile, servereid võib olla seejuures mitu
 <Plugin "network">
 Server "collectd0.example.com"
 </Plugin>

server

 LoadPlugin "network"
 <Plugin "network">
 Listen "collectd0.example.com"
 Listen "ff18::efc0:4a42"
 </Plugin>
 
 LoadPlugin "rrdtool"
 
 <Plugin "rrdtool">
 DataDir "/var/lib/collectd/rrd"
 </Plugin>

Proxy

LoadPlugin "network"
<Plugin "network">
Listen "collectgw.extern.example.com"
Server "collectd1.intern.example.com"
Forward true
</Plugin>

Collectd web

Collektus.png

Keerukamad kasutusjuhud

Kindlad protsessid

LoadPlugin processes                                                                                      

<Plugin processes>                                                                                        
        Process uhttpd                                                                                    
        Process dnsmasq                                                                                   
        Process dropbear                                                                                  
</Plugin>

Skripti käivitamine, antud näites loeb skript kokku faile postfixi järjekorra kaustadest

LoadPlugin exec
<Plugin exec>
  Exec "postfix:postfix" "/etc/collectd.d/collectd-postfix.sh"
</Plugin>

collectd-postfix.sh

#!/bin/bash

INTERVAL=60
POSTFIX_QDIR=/var/spool/postfix

while :; do
  time=$(date +%s)
  for q in incoming active deferred corrupt hold; do
    count=$(find $POSTFIX_QDIR/$q -type f -print | wc -l)
    eval "$q=$count"
  done
  echo "PUTVAL \"$HOSTNAME/postfix/postfix_queue\" interval=$INTERVAL $time:$incoming:$active:$deferred:$corrupt:$hold"
  sleep $INTERVAL
done

https://collectd.org/wiki/index.php/Plugin:cURL/Config curli kasutamine veebit või failidest alginfo saamiseks

https://wiki.postgresql.org/images/b/bc/Pgconfeu12-collectd%2Bpsql.pdf postgresqli detailsem jälgimine

Temperatuurianduri andmed failist

Kasutusel on Beaglebone Black, mille GPIO külge on joodetud kaks temperatuuriandurit

Kaks andurit, kumbki annab eraldi failist väljundit

10-00080013237c
10-0008001327a7

Näiteks

# cat /sys/devices/w1_bus_master1/10-0008001327a7/w1_slave 
24 00 4b 46 ff ff 09 10 53 : crc=53 YES
24 00 4b 46 ff ff 09 10 53 t=18187

seal t=17375 on temperatuur millikraadides.

Järgnev konfilõik loeb curliga failist info, korjab sellest regexpi abil millikraadides temperatuuri, ja viimaks teisendab millikraadid normaalseteks ühikuteks

 # laadime vajalikud pluginad
 LoadPlugin curl
 LoadPlugin match_regex
 LoadPlugin target_scale
 
 <Plugin curl>
   <Page "Cont1_T">
     URL "file:///sys/devices/w1_bus_master1/10-0008001327a7/w1_slave"
       <Match>
 	Regex "t=(-?[0-9]+)" 
         DSType "GaugeLast"
         Type "temperature"
         Instance "Andur 1"
       </Match>
   </Page>
   <Page "Cont2_T">
     URL "file:///sys/devices/w1_bus_master1/10-00080013237c/w1_slave"
       <Match>
         Regex "t=(-?[0-9]+)"
         DSType "GaugeLast"
         Type "temperature"
         Instance "Andur 2"
       </Match>
   </Page>
 </Plugin>
 
 <Chain "PreCache">
   <Rule "m_to_c">
     <Match "regex">
       Plugin "^curl$"
       Type "^temperature$"
     </Match>
     <Target "scale">
      Factor 0.001 
     </Target>
   </Rule>
 </Chain>

UPSi andmete lugemine

Võrgu-upside puhul oleks tarvis paigaldada ja seadistada nut tarkvara

/etc/nut/ups.conf

[juurups]
  driver = snmp-ups
  port = 10.1.1.7
  community = public
  snmp_version = v2c
  mibs = ietf
  pollfreq = 60

collectd konfiguratsioon

<Plugin nut>
        UPS "juurups@localhost:3493"
</Plugin>