in reply to Re^3: Real time log parser
in thread Real time log parser
#!/usr/bin/perl # Squid reconfiguration script rev: 0.87 # use File::Tail; my (@tmpl,@cut); sub ban { open( CFG, "<", "/etc/squid/squid.conf" ); while ( <CFG> ) { push @cfg, $_; } close(CFG); my @cutoff = grep /proxy_/,@_; s/ROUNDROBIN_PARENT\///g for @cutoff; @cutoff = grep /@cutoff/,@cfg; open( GREY, ">", "/etc/squid/all.grey" ); if (@cutoff) { print GREY @cutoff; print GREY "10\n"; } close (GREY); print "Banned parrent: @cutoff\n"; print " Strings with parrent in conf: @cutoff\n"; open( EXC, ">", "/etc/squid/squid.conf" ); my %dels = map { $_ => 1 } @cutoff; @cfg = grep !$dels{$_}, @cfg; print EXC @cfg; close (EXC); @args = ("/etc/init.d/squid", "reload"); system(@args) == 0 or die "system @args failed: $?" ; } my $name = "/var/log/squid/access.log"; my $ref=tie *FH,"File::Tail",(name=>$name); while (<FH>) { my $res = ban ($_); m/\/sorry\// && ban ($_); }
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^5: Real time log parser
by Eliya (Vicar) on Jan 02, 2012 at 20:20 UTC | |
by kazak (Beadle) on Jan 02, 2012 at 21:35 UTC | |
by Eliya (Vicar) on Jan 02, 2012 at 22:51 UTC | |
by kazak (Beadle) on Jan 03, 2012 at 10:33 UTC | |
by Eliya (Vicar) on Jan 03, 2012 at 10:51 UTC |