Script for Exim-mail server
Moderators: Developers, Moderators
Script for Exim-mail server
Hi,
I'm searching for scripts and XML files to graph statistic of my Mail server - Exim. I have found a script on this forum but for Postfix and it doesn't work.
Somebody can help me ?
Thanks
I'm searching for scripts and XML files to graph statistic of my Mail server - Exim. I have found a script on this forum but for Postfix and it doesn't work.
Somebody can help me ?
Thanks
Here you go.
Here is a quick script I threw together for such a purpose. It's quick, dirty, and worked for me. YMMV. If you improve upon it, please post the new code to this topic or e-mail me.
Code: Select all
#!/usr/bin/perl
#
#
# exim_traffic.pl (c) 2004 Stephen Fulton (sfulton@connection.ca)
#
# Free to use by anyone, anywhere. I only as that if you improve upon
# the code (and it can definitely be improved), send me a copy.
#
# Very basic perl script to parse an Exim (v4) log file and return
# a number based on the counted instances every 5 minutes.
#
# I originally wrote this for use in our Cacti install, but it can work
# with MRTG or any other time based stats tool. For use on external machines,
# I recommend you look into running this script via SNMP -- have Cacti poll
# the machine using a custom OID of your choice, and have it execute this script.
# As far as how to do it, maybe I'll include instructions later. YMMV.
#
# Syntax & Comments:
#
# in = Number of inbound messages
# out = Number of outbound messages
# rbl = Real-time block list rejects (Change to reflect your logged messages)
# rejecteduser = Number of rejected recipients (good for noting dictionary attacks)
#
#######################################################################################
use POSIX qw(strftime);
## Replace with the location and name of your main Exim log file
##
$EXIM_LOG = "/var/log/exim/exim_mainlog";
##
##
$inbound = 0;
$outbound = 0;
$rbl = 0;
$rejected_users = 0;
print "$EXIM_LOG\n";
open(LOG, $EXIM_LOG) || die "$0: Could not open Exim log: $!";
## Okay this is cheap -- fix this. SLOPPY SLOPPY SLOPPY.
## It will be mostly accurate, but not entirely. More code is needed.
##
$fivemin = strftime("%Y-%m-%d %H:%M", gmtime(time-14700));
$fourmin = strftime("%Y-%m-%d %H:%M", gmtime(time-14640));
$threemin = strftime("%Y-%m-%d %H:%M", gmtime(time-14580));
$twomin = strftime("%Y-%m-%d %H:%M", gmtime(time-14520));
$onemin = strftime("%Y-%m-%d %H:%M", gmtime(time-14460));
$zeromin = strftime("%Y-%m-%d %H:%M", gmtime(time-14400));
while(<LOG>) {
next unless (/^$fivemin/ || /^$fourmin/ || /^$threemin/ || /^$twomin/ || /^$onemin/ || /^$zeromin/);
if (/<=/) {
$inbound++;
} elsif(/[-=]>/) {
$outbound++;
} elsif(/RBL:/) {
$rbl++;
} elsif(/rejected RCPT/) {
$rejected_users++;
}
}
$argument = lc($ARGV[0]);
if($argument eq 'in') { print "$inbound\n"; }
elsif($argument eq 'out') { print "$outbound\n"; }
elsif($argument eq 'rbl') { print "$rbl\n"; }
elsif($argument eq 'rejectedusers') { print "$rejected_users\n"; }
else {
print "exim4_traffic.pl\n\n";
print "in\t\tReport inbound messages.\n";
print "out\t\tReport outbound messages.\n";
print "rbl\t\tReport number of RBL rejects.\n";
print "rejecteduser\t\tReport number of rejected users (dictionary attacks).\n";
}
-
- Posts: 35
- Joined: Wed Nov 10, 2004 5:43 am
- Location: Stockholm
- Contact:
I changed the script a bit...I'm no perl programmer so feel free to point out any bad practices Anyway, it's working for me.
I'm also quite new to cacti so if there's a better way do this, point that out to
/usr/local/share/snmp/scripts/exim.cron.pl:
I run the above script from cron:
/usr/local/share/snmp/scripts/cron:
I read the data from the output/ files with scripts and snmp.
snmpd.conf:
exim-traffic script is simple:
the others look the same.
After you added the lines snmpd.conf do a kill -HUP snmpd-pid and:
run script: /usr/local/share/snmp/scripts/exim.cron.pl
try this: snmpwalk -v 2c -c public localhost .1.3.6.1.4.1.3032
Should give you something like:
Nothing left but to get the data in to cacti:
exim-traffic:
Input parameters
$1 is communityname
$2 is hostname
I'm also quite new to cacti so if there's a better way do this, point that out to
/usr/local/share/snmp/scripts/exim.cron.pl:
Code: Select all
#!/usr/bin/perl
#
#
# exim_traffic.pl (c) 2004 Stephen Fulton (sfulton@connection.ca)
#
# Modified by:
# 2004-11-09 Goran Tornqvist (goran-nospam@aleborg.se)
# * Changed from gmdate to localtime (works for me with CET)
# * Added extra checking in logfile. Failed deliveries, etc
# * Writing output to files instead of stdout
#
# Free to use by anyone, anywhere. I only as that if you improve upon
# the code (and it can definitely be improved), send me a copy.
#
# Very basic perl script to parse an Exim (v4) log file and return
# a number based on the counted instances every 5 minutes.
#
# I originally wrote this for use in our Cacti install, but it can work
# with MRTG or any other time based stats tool. For use on external machines,
# I recommend you look into running this script via SNMP -- have Cacti poll
# the machine using a custom OID of your choice, and have it execute this script.
# As far as how to do it, maybe I'll include instructions later. YMMV.
#
# Syntax & Comments:
#
# in = Number of inbound messages
# out = Number of outbound messages
# rbl = Real-time block list rejects (Change to reflect your logged messages)
# rejecteduser = Number of rejected recipients (good for noting dictionary attacks)
# rejected_data = Number of messages rejected because of contents (viruses)
# rejected_by_filter = Number of messages rejected by the filter (like .pif .com files)
# del_failed = Number of failed deliveries (permanent errors)
# del_deferred = Number of deferred deliveries (temporary errors)
#
#######################################################################################
use POSIX qw(strftime);
## Replace with the location and name of your main Exim log file
##
$EXIM_LOG = "/var/log/exim/exim_mainlog";
##
##
$inbound = 0;
$outbound = 0;
$rbl = 0;
$rejected_users = 0;
$rejected_data = 0;
$rejected_by_filter = 0;
$del_failed = 0;
$del_deferred = 0;
$del_deferred = 0;
#print "$EXIM_LOG\n";
open(LOG, $EXIM_LOG) || die "$0: Could not open Exim log: $!";
## Okay this is cheap -- fix this. SLOPPY SLOPPY SLOPPY.
## It will be mostly accurate, but not entirely. More code is needed.
##
$fivemin = strftime("%Y-%m-%d %H:%M", localtime(time-300));
$fourmin = strftime("%Y-%m-%d %H:%M", localtime(time-240));
$threemin = strftime("%Y-%m-%d %H:%M", localtime(time-180));
$twomin = strftime("%Y-%m-%d %H:%M", localtime(time-120));
$onemin = strftime("%Y-%m-%d %H:%M", localtime(time-60));
$zeromin = strftime("%Y-%m-%d %H:%M", localtime(time));
while(<LOG>) {
next unless (/^$fivemin/ || /^$fourmin/ || /^$threemin/ || /^$twomin/ || /^$onemin/ || /^$zeromin/);
if (/<=/) {
$inbound++;
} elsif(/[-=]>/) {
$outbound++;
} elsif(/\*\*/) {
$del_failed++;
} elsif(/==/) {
$del_deferred++;
} elsif(/RBL:/) {
$rbl++;
} elsif(/rejected RCPT/) {
$rejected_users++;
} elsif(/rejected after DATA/) {
$rejected_data++;
} elsif(/cancelled by system filter/) {
$rejected_by_filter++;
}
}
$file1 = "/usr/local/share/snmp/scripts/output/exim-traffic.output";
open($fh1,">$file1") or die("Could not open file $file1\n");
print $fh1 "inbound:$inbound outbound:$outbound";
close($fh1);
$file2 = "/usr/local/share/snmp/scripts/output/exim-rejected.output";
open($fh2,">$file2") or die("Could not open file $file2\n");
print $fh2 "rejected_users=$rejected_users rejected_data:$rejected_data rejected_by_filter:$rejected_by_filter";
close($fh2);
$file3 = "/usr/local/share/snmp/scripts/output/exim-delivery.output";
open($fh3,">$file3") or die("Could not open file $file3\n");
print $fh3 "del_failed:$del_failed del_deferred:$del_deferred";
close($fh3);
# COMMENTED OUT - Im not using RBLs. print " rbl=$rbl";
Code: Select all
# SNMP Scripts
*/5 * * * * /usr/local/share/snmp/scripts/cron > /dev/null 2>&1
Code: Select all
#!/usr/local/bin/bash
#SNMP scripts
/usr/local/share/snmp/scripts/exim.cron.pl >/usr/local/share/snmp/scripts/exim.cron.log
snmpd.conf:
Code: Select all
#Custom OIDs
exec .1.3.6.1.4.1.3032.64 exim-traffic /usr/local/share/snmp/scripts/exim-traffic
exec .1.3.6.1.4.1.3032.65 exim-rejected /usr/local/share/snmp/scripts/exim-rejected
exec .1.3.6.1.4.1.3032.66 exim-delivery /usr/local/share/snmp/scripts/exim-delivery
Code: Select all
#!/usr/local/bin/bash
cat /usr/local/share/snmp/scripts/output/exim-traffic.output
After you added the lines snmpd.conf do a kill -HUP snmpd-pid and:
run script: /usr/local/share/snmp/scripts/exim.cron.pl
try this: snmpwalk -v 2c -c public localhost .1.3.6.1.4.1.3032
Should give you something like:
Code: Select all
SNMPv2-SMI::enterprises.3032.64.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.64.2.1 = STRING: "exim-traffic"
SNMPv2-SMI::enterprises.3032.64.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-traffic"
SNMPv2-SMI::enterprises.3032.64.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.101.1 = STRING: "inbound:1 outbound:1"
SNMPv2-SMI::enterprises.3032.64.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.65.2.1 = STRING: "exim-rejected"
SNMPv2-SMI::enterprises.3032.65.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-rejected"
SNMPv2-SMI::enterprises.3032.65.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.101.1 = STRING: "rejected_users:0 rejected_data:0 rejected_by_filter:0"
SNMPv2-SMI::enterprises.3032.65.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.66.2.1 = STRING: "exim-delivery"
SNMPv2-SMI::enterprises.3032.66.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-delivery"
SNMPv2-SMI::enterprises.3032.66.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.101.1 = STRING: "del_failed:0 del_deferred:0"
SNMPv2-SMI::enterprises.3032.66.102.1 = INTEGER: 0
exim-traffic:
Code: Select all
#!/usr/local/bin/bash
snmpdata=`snmpget -v 2c -c $1 $2 .1.3.6.1.4.1.3032.64.101.1 | awk -F"\"" '{ print $2 }'`
echo $snmpdata
$1 is communityname
$2 is hostname
i tried this, but i get:
root@host [~]# ./exim-traffic public athens.dnsrouter.com
stdin: is not a tty
root@host [~]#
also when doing an snmpwalk, i get the following:
SNMPv2-SMI::enterprises.3032.64.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.64.2.1 = STRING: "exim-traffic"
SNMPv2-SMI::enterprises.3032.64.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-traffic"
SNMPv2-SMI::enterprises.3032.64.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.101.1 = STRING: "stdin: is not a tty"
SNMPv2-SMI::enterprises.3032.64.101.2 = STRING: "inbound:49 outbound:47"
SNMPv2-SMI::enterprises.3032.64.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.103.1 = ""
SNMPv2-SMI::enterprises.3032.65.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.65.2.1 = STRING: "exim-rejected"
SNMPv2-SMI::enterprises.3032.65.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-rejected"
SNMPv2-SMI::enterprises.3032.65.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.101.1 = STRING: "stdin: is not a tty"
SNMPv2-SMI::enterprises.3032.65.101.2 = STRING: "rejected_users=65 rejected_data:2 rejected_by_filter:1"
SNMPv2-SMI::enterprises.3032.65.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.103.1 = ""
SNMPv2-SMI::enterprises.3032.66.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.66.2.1 = STRING: "exim-delivery"
SNMPv2-SMI::enterprises.3032.66.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-delivery"
SNMPv2-SMI::enterprises.3032.66.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.101.1 = STRING: "stdin: is not a tty"
SNMPv2-SMI::enterprises.3032.66.101.2 = STRING: "del_failed:4 del_deferred:5"
SNMPv2-SMI::enterprises.3032.66.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.103.1 = ""
note the stdin: is not a tty how do i get rid of this?
root@host [~]# ./exim-traffic public athens.dnsrouter.com
stdin: is not a tty
root@host [~]#
also when doing an snmpwalk, i get the following:
SNMPv2-SMI::enterprises.3032.64.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.64.2.1 = STRING: "exim-traffic"
SNMPv2-SMI::enterprises.3032.64.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-traffic"
SNMPv2-SMI::enterprises.3032.64.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.101.1 = STRING: "stdin: is not a tty"
SNMPv2-SMI::enterprises.3032.64.101.2 = STRING: "inbound:49 outbound:47"
SNMPv2-SMI::enterprises.3032.64.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.103.1 = ""
SNMPv2-SMI::enterprises.3032.65.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.65.2.1 = STRING: "exim-rejected"
SNMPv2-SMI::enterprises.3032.65.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-rejected"
SNMPv2-SMI::enterprises.3032.65.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.101.1 = STRING: "stdin: is not a tty"
SNMPv2-SMI::enterprises.3032.65.101.2 = STRING: "rejected_users=65 rejected_data:2 rejected_by_filter:1"
SNMPv2-SMI::enterprises.3032.65.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.103.1 = ""
SNMPv2-SMI::enterprises.3032.66.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.66.2.1 = STRING: "exim-delivery"
SNMPv2-SMI::enterprises.3032.66.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-delivery"
SNMPv2-SMI::enterprises.3032.66.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.101.1 = STRING: "stdin: is not a tty"
SNMPv2-SMI::enterprises.3032.66.101.2 = STRING: "del_failed:4 del_deferred:5"
SNMPv2-SMI::enterprises.3032.66.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.103.1 = ""
note the stdin: is not a tty how do i get rid of this?
-
- Posts: 18
- Joined: Thu Oct 27, 2005 9:24 am
- Location: Germany, Bavaria
Hello,
i tested this Script and get also an error:
Is there an wrong Syntax??
No Hostname? No such file or directory??
Can someone Help me?
i tested this Script and get also an error:
Code: Select all
mail:/usr/local/share/cacti/scripts# snmpget -v 2c -c public localhost .1.3.6.1.4.1.3032
SNMPv2-SMI::enterprises.3032 = No Such Object available on this agent at this OID
mail:/usr/local/share/cacti/scripts# snmpwalk -v 2c -c public localhost .1.3.6.1.4.1.3032
SNMPv2-SMI::enterprises.3032.64.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.64.2.1 = STRING: "exim-traffic"
SNMPv2-SMI::enterprises.3032.64.3.1 = STRING: "/usr/local/share/cacti/scripts/exim-traffic"
SNMPv2-SMI::enterprises.3032.64.100.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.101.1 = STRING: "No hostname specified."
SNMPv2-SMI::enterprises.3032.64.101.2 = STRING: "USAGE: snmpget [OPTIONS] AGENT OID [OID]..."
SNMPv2-SMI::enterprises.3032.64.101.3 = ""
SNMPv2-SMI::enterprises.3032.64.101.4 = STRING: " Version: 5.1.2"
SNMPv2-SMI::enterprises.3032.64.101.5 = STRING: " Web: http://www.net-snmp.org/"
SNMPv2-SMI::enterprises.3032.64.101.6 = STRING: " Email: net-snmp-coders@lists.sourceforge.net"
SNMPv2-SMI::enterprises.3032.64.101.7 = ""
SNMPv2-SMI::enterprises.3032.64.101.8 = STRING: "OPTIONS:"
SNMPv2-SMI::enterprises.3032.64.101.9 = STRING: " -h, --help..display this help message"
SNMPv2-SMI::enterprises.3032.64.101.10 = STRING: " -H...display configuration file directives understood"
SNMPv2-SMI::enterprises.3032.64.101.11 = STRING: " -v 1|2c|3..specifies SNMP version to use"
SNMPv2-SMI::enterprises.3032.64.101.12 = STRING: " -V, --version..display package version number"
SNMPv2-SMI::enterprises.3032.64.101.13 = STRING: "SNMP Version 1 or 2c specific"
SNMPv2-SMI::enterprises.3032.64.101.14 = STRING: " -c COMMUNITY..set the community string"
SNMPv2-SMI::enterprises.3032.64.101.15 = STRING: "SNMP Version 3 specific"
SNMPv2-SMI::enterprises.3032.64.101.16 = STRING: " -a PROTOCOL..set authentication protocol (MD5|SHA)"
SNMPv2-SMI::enterprises.3032.64.101.17 = STRING: " -A PASSPHRASE..set authentication protocol pass phrase"
SNMPv2-SMI::enterprises.3032.64.101.18 = STRING: " -e ENGINE-ID..set security engine ID (e.g. 800000020109840301)"
SNMPv2-SMI::enterprises.3032.64.101.19 = STRING: " -E ENGINE-ID..set context engine ID (e.g. 800000020109840301)"
SNMPv2-SMI::enterprises.3032.64.101.20 = STRING: " -l LEVEL..set security level (noAuthNoPriv|authNoPriv|authPriv)"
SNMPv2-SMI::enterprises.3032.64.101.21 = STRING: " -n CONTEXT..set context name (e.g. bridge1)"
SNMPv2-SMI::enterprises.3032.64.101.22 = STRING: " -u USER-NAME..set security name (e.g. bert)"
SNMPv2-SMI::enterprises.3032.64.101.23 = STRING: " -x PROTOCOL..set privacy protocol (DES)"
SNMPv2-SMI::enterprises.3032.64.101.24 = STRING: " -X PASSPHRASE..set privacy protocol pass phrase"
SNMPv2-SMI::enterprises.3032.64.101.25 = STRING: " -Z BOOTS,TIME..set destination engine boots/time"
SNMPv2-SMI::enterprises.3032.64.101.26 = STRING: "General communicat"
SNMPv2-SMI::enterprises.3032.64.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.64.103.1 = ""
SNMPv2-SMI::enterprises.3032.65.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.65.2.1 = STRING: "exim-rejected"
SNMPv2-SMI::enterprises.3032.65.3.1 = STRING: "/usr/local/share/cacti/scripts/exim-rejected"
SNMPv2-SMI::enterprises.3032.65.100.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.65.101.1 = STRING: "/usr/local/share/cacti/scripts/exim-rejected: No such file or directory"
SNMPv2-SMI::enterprises.3032.65.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.65.103.1 = ""
SNMPv2-SMI::enterprises.3032.66.1.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.66.2.1 = STRING: "exim-delivery"
SNMPv2-SMI::enterprises.3032.66.3.1 = STRING: "/usr/local/share/cacti/scripts/exim-delivery"
SNMPv2-SMI::enterprises.3032.66.100.1 = INTEGER: 1
SNMPv2-SMI::enterprises.3032.66.101.1 = STRING: "/usr/local/share/cacti/scripts/exim-delivery: No such file or directory"
SNMPv2-SMI::enterprises.3032.66.102.1 = INTEGER: 0
SNMPv2-SMI::enterprises.3032.66.103.1 = ""
mail:/usr/local/share/cacti/scripts#
No Hostname? No such file or directory??
Can someone Help me?
do you have a XML file for this nice script?
thx
thx
GoranTornqvist wrote:I changed the script a bit...I'm no perl programmer so feel free to point out any bad practices Anyway, it's working for me.
I'm also quite new to cacti so if there's a better way do this, point that out to
/usr/local/share/snmp/scripts/exim.cron.pl:I run the above script from cron:Code: Select all
#!/usr/bin/perl # # # exim_traffic.pl (c) 2004 Stephen Fulton (sfulton@connection.ca) # # Modified by: # 2004-11-09 Goran Tornqvist (goran-nospam@aleborg.se) # * Changed from gmdate to localtime (works for me with CET) # * Added extra checking in logfile. Failed deliveries, etc # * Writing output to files instead of stdout # # Free to use by anyone, anywhere. I only as that if you improve upon # the code (and it can definitely be improved), send me a copy. # # Very basic perl script to parse an Exim (v4) log file and return # a number based on the counted instances every 5 minutes. # # I originally wrote this for use in our Cacti install, but it can work # with MRTG or any other time based stats tool. For use on external machines, # I recommend you look into running this script via SNMP -- have Cacti poll # the machine using a custom OID of your choice, and have it execute this script. # As far as how to do it, maybe I'll include instructions later. YMMV. # # Syntax & Comments: # # in = Number of inbound messages # out = Number of outbound messages # rbl = Real-time block list rejects (Change to reflect your logged messages) # rejecteduser = Number of rejected recipients (good for noting dictionary attacks) # rejected_data = Number of messages rejected because of contents (viruses) # rejected_by_filter = Number of messages rejected by the filter (like .pif .com files) # del_failed = Number of failed deliveries (permanent errors) # del_deferred = Number of deferred deliveries (temporary errors) # ####################################################################################### use POSIX qw(strftime); ## Replace with the location and name of your main Exim log file ## $EXIM_LOG = "/var/log/exim/exim_mainlog"; ## ## $inbound = 0; $outbound = 0; $rbl = 0; $rejected_users = 0; $rejected_data = 0; $rejected_by_filter = 0; $del_failed = 0; $del_deferred = 0; $del_deferred = 0; #print "$EXIM_LOG\n"; open(LOG, $EXIM_LOG) || die "$0: Could not open Exim log: $!"; ## Okay this is cheap -- fix this. SLOPPY SLOPPY SLOPPY. ## It will be mostly accurate, but not entirely. More code is needed. ## $fivemin = strftime("%Y-%m-%d %H:%M", localtime(time-300)); $fourmin = strftime("%Y-%m-%d %H:%M", localtime(time-240)); $threemin = strftime("%Y-%m-%d %H:%M", localtime(time-180)); $twomin = strftime("%Y-%m-%d %H:%M", localtime(time-120)); $onemin = strftime("%Y-%m-%d %H:%M", localtime(time-60)); $zeromin = strftime("%Y-%m-%d %H:%M", localtime(time)); while(<LOG>) { next unless (/^$fivemin/ || /^$fourmin/ || /^$threemin/ || /^$twomin/ || /^$onemin/ || /^$zeromin/); if (/<=/) { $inbound++; } elsif(/[-=]>/) { $outbound++; } elsif(/\*\*/) { $del_failed++; } elsif(/==/) { $del_deferred++; } elsif(/RBL:/) { $rbl++; } elsif(/rejected RCPT/) { $rejected_users++; } elsif(/rejected after DATA/) { $rejected_data++; } elsif(/cancelled by system filter/) { $rejected_by_filter++; } } $file1 = "/usr/local/share/snmp/scripts/output/exim-traffic.output"; open($fh1,">$file1") or die("Could not open file $file1\n"); print $fh1 "inbound:$inbound outbound:$outbound"; close($fh1); $file2 = "/usr/local/share/snmp/scripts/output/exim-rejected.output"; open($fh2,">$file2") or die("Could not open file $file2\n"); print $fh2 "rejected_users=$rejected_users rejected_data:$rejected_data rejected_by_filter:$rejected_by_filter"; close($fh2); $file3 = "/usr/local/share/snmp/scripts/output/exim-delivery.output"; open($fh3,">$file3") or die("Could not open file $file3\n"); print $fh3 "del_failed:$del_failed del_deferred:$del_deferred"; close($fh3); # COMMENTED OUT - Im not using RBLs. print " rbl=$rbl";
/usr/local/share/snmp/scripts/cron:Code: Select all
# SNMP Scripts */5 * * * * /usr/local/share/snmp/scripts/cron > /dev/null 2>&1
I read the data from the output/ files with scripts and snmp.Code: Select all
#!/usr/local/bin/bash #SNMP scripts /usr/local/share/snmp/scripts/exim.cron.pl >/usr/local/share/snmp/scripts/exim.cron.log
snmpd.conf:exim-traffic script is simple:Code: Select all
#Custom OIDs exec .1.3.6.1.4.1.3032.64 exim-traffic /usr/local/share/snmp/scripts/exim-traffic exec .1.3.6.1.4.1.3032.65 exim-rejected /usr/local/share/snmp/scripts/exim-rejected exec .1.3.6.1.4.1.3032.66 exim-delivery /usr/local/share/snmp/scripts/exim-delivery
the others look the same.Code: Select all
#!/usr/local/bin/bash cat /usr/local/share/snmp/scripts/output/exim-traffic.output
After you added the lines snmpd.conf do a kill -HUP snmpd-pid and:
run script: /usr/local/share/snmp/scripts/exim.cron.pl
try this: snmpwalk -v 2c -c public localhost .1.3.6.1.4.1.3032
Should give you something like:Nothing left but to get the data in to cacti:Code: Select all
SNMPv2-SMI::enterprises.3032.64.1.1 = INTEGER: 1 SNMPv2-SMI::enterprises.3032.64.2.1 = STRING: "exim-traffic" SNMPv2-SMI::enterprises.3032.64.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-traffic" SNMPv2-SMI::enterprises.3032.64.100.1 = INTEGER: 0 SNMPv2-SMI::enterprises.3032.64.101.1 = STRING: "inbound:1 outbound:1" SNMPv2-SMI::enterprises.3032.64.102.1 = INTEGER: 0 SNMPv2-SMI::enterprises.3032.65.1.1 = INTEGER: 1 SNMPv2-SMI::enterprises.3032.65.2.1 = STRING: "exim-rejected" SNMPv2-SMI::enterprises.3032.65.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-rejected" SNMPv2-SMI::enterprises.3032.65.100.1 = INTEGER: 0 SNMPv2-SMI::enterprises.3032.65.101.1 = STRING: "rejected_users:0 rejected_data:0 rejected_by_filter:0" SNMPv2-SMI::enterprises.3032.65.102.1 = INTEGER: 0 SNMPv2-SMI::enterprises.3032.66.1.1 = INTEGER: 1 SNMPv2-SMI::enterprises.3032.66.2.1 = STRING: "exim-delivery" SNMPv2-SMI::enterprises.3032.66.3.1 = STRING: "/usr/local/share/snmp/scripts/exim-delivery" SNMPv2-SMI::enterprises.3032.66.100.1 = INTEGER: 0 SNMPv2-SMI::enterprises.3032.66.101.1 = STRING: "del_failed:0 del_deferred:0" SNMPv2-SMI::enterprises.3032.66.102.1 = INTEGER: 0
exim-traffic:Input parametersCode: Select all
#!/usr/local/bin/bash snmpdata=`snmpget -v 2c -c $1 $2 .1.3.6.1.4.1.3032.64.101.1 | awk -F""" '{ print $2 }'` echo $snmpdata
$1 is communityname
$2 is hostname
Who is online
Users browsing this forum: No registered users and 2 guests