… | |
… | |
9 | use Text::Abbrev; |
9 | use Text::Abbrev; |
10 | |
10 | |
11 | my $last_ts = time; |
11 | my $last_ts = time; |
12 | |
12 | |
13 | my %complete; |
13 | my %complete; |
14 | my @commands = qw(quit squit refresh country restart block info print); |
14 | my @commands = qw(quit squit refresh country restart block info print clrdiridx); |
15 | |
15 | |
16 | abbrev \%complete, @commands; |
16 | abbrev \%complete, @commands; |
17 | |
17 | |
18 | sub shell { |
18 | sub shell { |
19 | my $fh = shift; |
19 | my $fh = shift; |
… | |
… | |
45 | push @data, "$_->{country}/$_->{remote_addr} $_->{written} $rate $_->{method} $_->{uri}\n"; |
45 | push @data, "$_->{country}/$_->{remote_addr} $_->{written} $rate $_->{method} $_->{uri}\n"; |
46 | } |
46 | } |
47 | } |
47 | } |
48 | print $fh sort @data; |
48 | print $fh sort @data; |
49 | print $fh scalar@data, " ($::conns) connections\n";#d# |
49 | print $fh scalar@data, " ($::conns) connections\n";#d# |
50 | print $fh "$::written bytes written in the last ",$::NOW - $last_ts, " seconds\n"; |
50 | print $fh "$::written bytes written in the last ", $::NOW - $last_ts, " seconds\n"; |
51 | printf $fh "(%.1f bytes/s)\n", $::written / ($::NOW - $last_ts); |
51 | printf $fh "(%.1f bytes/s)\n", $::written / ($::NOW - $last_ts); |
52 | ($last_ts, $::written) = ($::NOW, 0); |
52 | ($last_ts, $::written) = ($::NOW, 0); |
53 | } elsif ($cmd eq "refresh") { |
53 | } elsif ($cmd eq "refresh") { |
54 | do "config.pl"; |
54 | do "config.pl"; |
55 | print $fh "config.pl: $@\n" if $@; |
55 | print $fh "config.pl: $@\n" if $@; |
|
|
56 | %statdata_cache = (); |
56 | read_blockuri; |
57 | conn::read_blockuri; |
57 | read_blockref; |
58 | conn::read_blockref; |
|
|
59 | } elsif ($cmd eq "clrdiridx") { |
|
|
60 | %statdata_cache = (); |
|
|
61 | %diridx = (); |
58 | } elsif ($cmd eq "restart") { |
62 | } elsif ($cmd eq "restart") { |
59 | $::RESTART = 1; |
63 | $::RESTART = 1; |
60 | unloop; |
64 | unloop; |
61 | print $fh "restarting, cu!\n"; |
65 | print $fh "restarting, cu!\n"; |
62 | last; |
66 | last; |
63 | } elsif ($cmd eq "country") { |
67 | } elsif ($cmd eq "country") { |
64 | print $fh ip_request($_), "\n"; |
68 | print $fh netgeo::ip_request($_), "\n"; |
65 | } |
69 | } |
66 | } else { |
70 | } else { |
67 | print $fh "try one of @commands\n"; |
71 | print $fh "try one of @commands\n"; |
68 | } |
72 | } |
69 | } |
73 | } |