ispCP - Board - Support
proftpd munin telepítési probléma - Printable Version

+- ispCP - Board - Support (http://www.isp-control.net/forum)
+-- Forum: ispCP Omega International Area (/forum-22.html)
+--- Forum: Hungary Corner (/forum-46.html)
+--- Thread: proftpd munin telepítési probléma (/thread-12239.html)

Pages: 1 2 3


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 Wink

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. Smile


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. Sad 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. Sad 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. Smile
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! Smile
[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}"