proftpd munin telepítési probléma - romantik - 11-25-2010 06:30 PM
Feltettem a közösbe, de hátha itt van nagyobb agy
Az alap probléma: munint használok, és feltettem két plugint hozzá:
proftpd_count
proftpd_bytes
A probléma az, hogy semmit nem rajzol az istenátka... Valakinek van ötlete mit kéne módosítani a konfigján?
Én már oda-vissza mókoltam, de semmi eredménye...
Mielőtt kérdeznétek: ez az eredeti script, de az xferlog elérését módosítottam erre:
Code:
/var/log/proftpd/xferlog
proftpd_count:
Code:
#!/bin/bash
#
# Plugin to monitor FTP files.
# based on previous work by jintxo
#
# Parameters understood:
#
# config (required)
# autoconf (optional)
#
# Magic markers (optional - used by munin-config and installation
# scripts):
#
#%# family=auto
#%# capabilities=autoconf
MAXLABEL=20
mktempfile () {
mktemp -t $1
}
LOGFILE=${logfile:-/var/log/xferlog}
LOGTAIL=${logtail:-`which logtail`}
STATEFILE=/var/lib/munin/plugin-state/xferlog-count.offset
if [ "$1" = "autoconf" ]; then
if [ -f "${LOGFILE}" -a -n "${LOGTAIL}" -a -x "${LOGTAIL}" ] ; then
echo yes
exit 0
else
echo no
exit 1
fi
fi
if [ "$1" = "config" ]; then
echo 'graph_title FTP Server Transfers'
echo 'graph_args --base 1000 -l 0'
echo 'graph_vlabel FTP Server Transfers'
echo 'graph_category FTP'
echo 'ftp_get.label Files GET'
echo 'ftp_put.label Files PUT'
exit 0
fi
ftp_get=U
ftp_put=U
TEMP_FILE=`mktempfile munin-xferlog-count.XXXXXX`
if [ -n "$TEMP_FILE" -a -f "$TEMP_FILE" ]
then
$LOGTAIL ${LOGFILE} $STATEFILE | grep "[[:space:]][oi][[:space:]]" > ${TEMP_FILE}
ftp_get=`grep "[[:space:]]o[[:space:]]" ${TEMP_FILE} | wc -l`
ftp_put=`grep "[[:space:]]i[[:space:]]" ${TEMP_FILE} | wc -l`
/bin/rm -f $TEMP_FILE
fi
echo "ftp_get.value ${ftp_get}"
echo "ftp_put.value ${ftp_put}"
proftpd_bytes:
Code:
#!/bin/bash
#
# Plugin to monitor FTP bytes.
# based on previous work by jintxo
#
# Parameters understood:
#
# config (required)
# autoconf (optional)
#
# Magic markers (optional - used by munin-config and installation
# scripts):
#
#%# family=auto
#%# capabilities=autoconf
MAXLABEL=20
mktempfile () {
mktemp -t $1
}
LOGFILE=${logfile:-/var/log/xferlog}
LOGTAIL=${logtail:-`which logtail`}
STATEFILE=/var/lib/munin/plugin-state/xferlog-bytes.offset
if [ "$1" = "autoconf" ]; then
if [ -f "${LOGFILE}" -a -n "${LOGTAIL}" -a -x "${LOGTAIL}" ] ; then
echo yes
exit 0
else
echo no
exit 1
fi
fi
if [ "$1" = "config" ]; then
echo 'graph_title FTP Server Bytes'
echo 'graph_args --base 1000 -l 0'
echo 'graph_vlabel FTP Server Bytes'
echo 'graph_category FTP'
echo 'ftp_get.label Bytes GET'
echo 'ftp_put.label Bytes PUT'
exit 0
fi
ftp_get=U
ftp_put=U
TEMP_FILE=`mktempfile munin-xferlog-bytes.XXXXXX`
if [ -n "$TEMP_FILE" -a -f "$TEMP_FILE" ]
then
$LOGTAIL ${LOGFILE} $STATEFILE | grep "[[:space:]][oi][[:space:]]" > ${TEMP_FILE}
ftp_get=`grep "[[:space:]]o[[:space:]]" ${TEMP_FILE} | awk '{s += $8} END { if ( s ) print s ; else print "0" }'`
ftp_put=`grep "[[:space:]]i[[:space:]]" ${TEMP_FILE} | awk '{s += $8} END { if ( s ) print s ; else print "0" }'`
/bin/rm -f $TEMP_FILE
fi
echo "ftp_get.value ${ftp_get}"
echo "ftp_put.value ${ftp_put}"
Ötlet?
RE: proftpd munin telepítési probléma - Dylan - 11-25-2010 11:39 PM
Sajnos ötletem nincs, viszont engem is érdekelne, mert akkor énis beletenném a muninba.
RE: proftpd munin telepítési probléma - Dylan - 03-09-2011 10:49 PM
Na feltettem most én is, hamarosan kiderül, hogy nálam működik e.
RE: proftpd munin telepítési probléma - Dylan - 03-10-2011 12:02 AM
Hát nem müxik. De ahogy nézem google találatok alapján, sehol se müxik, mindenhol 0-án húzza a csíkot. Gyanítom, hogy a log fájl szerkezete változhatott, nyomozom a dolgot.
RE: proftpd munin telepítési probléma - Mono - 03-10-2011 04:35 AM
Na hát ez engem is érdekelne!
RE: proftpd munin telepítési probléma - romantik - 03-10-2011 04:35 AM
(03-10-2011 12:02 AM)Dylan Wrote: Hát nem müxik. De ahogy nézem google találatok alapján, sehol se müxik, mindenhol 0-án húzza a csíkot. Gyanítom, hogy a log fájl szerkezete változhatott, nyomozom a dolgot.
nézegettem én is, remélem te nagyobb sikerrel jársz!
RE: proftpd munin telepítési probléma - Dylan - 03-10-2011 07:22 AM
Hát.. kezdtem feladni. Mikor shellben lefuttattam a plugint, akkor kaptam egy hibaüzenetet, hogy permission denied. Nem tudta olvasni az xferlog fájlt.
Aztán az mktempfile függvénnyel volt valami gáz, kivettem belőle.
Végre elkezdte beolvasni a fájlt, de folyton értelmezni és futtatni akarja a logfájl tartalmát, azt írja, hogy rossz parancs...
Namost a tesztelés közben valami változott, mert most meg "Text file busy" üzenetet kapok, tehát megint nem tudja olvasni a xferlog tartalmát...
Kezdem elveszíteni a türelmemet. Amúgy gyanítom, hogy az awk résznél van valami hiba, csak nem ismerem ezt, hogy mi alapján parseolja a sor tartalmát. Elvileg a 8. oszlopban van a feltöltött fájl mérete, de valamiért ez az egész sort beolvassa és hozzáadja az "s" értékéhez...
Ha van itt hozzáértő bash script író, megköszönném a segítségét.
Na mire megírtam a hozzászólást, megint le tudom futtatni.
Szóval ennyit ír most:
"/var/log/proftpd/xferlog: line 1: Web: command not found"
Ebből nekem az jön le, hogy valamiért futtatni akarja a sorban levő értéket éshát ugye nincs olyan parancs, hogy Wed. Ötlet?
RE: proftpd munin telepítési probléma - romantik - 03-10-2011 08:06 AM
én ott feladtam, hogy futtatni akarta...
RE: proftpd munin telepítési probléma - Dylan - 03-10-2011 05:18 PM
Na ugy néz ki, hogy sikerül, legalábbis most sikerült shell-ben a várt eredményt visszaadnia. Pár órán át tesztelem, aztán ha jól működik akkor felteszem a megoldást.
RE: proftpd munin telepítési probléma - Dylan - 03-10-2011 07:04 PM
Siker!
[attachment=1608]
[attachment=1609]
A logtail sort vettem ki. (ftp_get=... felett)
A teljes script:
proftpd_bytes-v1
Code:
#!/bin/bash
#
# Plugin to monitor FTP bytes.
# based on previous work by jintxo
#
# Parameters understood:
#
# config (required)
# autoconf (optional)
#
# Magic markers (optional - used by munin-config and installation
# scripts):
#
#%# family=auto
#%# capabilities=autoconf
MAXLABEL=20
mktempfile () {
mktemp -t $1
}
LOGFILE=${logfile:-/var/log/proftpd/xferlog}
LOGTAIL=${logtail:-`which logtail`}
STATEFILE='/var/lib/munin/plugin-state/xferlog-bytes.offset'
if [ "$1" = "autoconf" ]; then
if [ -f "${LOGFILE}" -a -n "${LOGTAIL}" -a -x "${LOGTAIL}" ] ; then
echo yes
exit 0
else
echo no
exit 1
fi
fi
if [ "$1" = "config" ]; then
echo 'graph_title FTP Server Bytes'
echo 'graph_args --base 1000 -l 0'
echo 'graph_vlabel FTP Server Bytes'
echo 'graph_category FTP'
echo 'ftp_get.label Bytes GET'
echo 'ftp_put.label Bytes PUT'
exit 0
fi
ftp_get=U
ftp_put=U
TEMP_FILE=`mktempfile munin-xferlog-bytes.XXXXXX`
if [ -n "$TEMP_FILE" -a -f "$TEMP_FILE" ]
then
grep "[[:space:]][oi][[:space:]]" > ${TEMP_FILE} ${LOGFILE}
ftp_get=`grep "[[:space:]]o[[:space:]]" ${TEMP_FILE} | awk '{s += $8} END { if ( s ) print s ; else print "0" }'`
ftp_put=`grep "[[:space:]]i[[:space:]]" ${TEMP_FILE} | awk '{s += $8} END { if ( s ) print s ; else print "0" }'`
/bin/rm -f $TEMP_FILE
fi
echo "ftp_get.value ${ftp_get}"
echo "ftp_put.value ${ftp_put}"
proftpd_count-v1
Code:
#!/bin/bash
#
# Plugin to monitor FTP files.
# based on previous work by jintxo
#
# Parameters understood:
#
# config (required)
# autoconf (optional)
#
# Magic markers (optional - used by munin-config and installation
# scripts):
#
#%# family=auto
#%# capabilities=autoconf
MAXLABEL=20
mktempfile () {
mktemp -t $1
}
LOGFILE=${logfile:-/var/log/proftpd/xferlog}
LOGTAIL=${logtail:-`which logtail`}
STATEFILE=/var/lib/munin/plugin-state/xferlog-count.offset
if [ "$1" = "autoconf" ]; then
if [ -f "${LOGFILE}" -a -n "${LOGTAIL}" -a -x "${LOGTAIL}" ] ; then
echo yes
exit 0
else
echo no
exit 1
fi
fi
if [ "$1" = "config" ]; then
echo 'graph_title FTP Server Transfers'
echo 'graph_args --base 1000 -l 0'
echo 'graph_vlabel FTP Server Transfers'
echo 'graph_category FTP'
echo 'ftp_get.label Files GET'
echo 'ftp_put.label Files PUT'
exit 0
fi
ftp_get=U
ftp_put=U
TEMP_FILE=`mktempfile munin-xferlog-count.XXXXXX`
if [ -n "$TEMP_FILE" -a -f "$TEMP_FILE" ]
then
grep "[[:space:]][oi][[:space:]]" > ${TEMP_FILE} ${LOGFILE}
ftp_get=`grep "[[:space:]]o[[:space:]]" ${TEMP_FILE} | wc -l`
ftp_put=`grep "[[:space:]]i[[:space:]]" ${TEMP_FILE} | wc -l`
/bin/rm -f $TEMP_FILE
fi
echo "ftp_get.value ${ftp_get}"
echo "ftp_put.value ${ftp_put}"
|