1 | #!/usr/bin/perl
|
---|
2 | # ipdb/cgi-bin/freespace.pl
|
---|
3 | # Quick hack to calculate aggregate free IP space, and statistic-ify the blocks.
|
---|
4 | ###
|
---|
5 | # SVN revision info
|
---|
6 | # $Date: 2006-04-04 22:25:28 +0000 (Tue, 04 Apr 2006) $
|
---|
7 | # SVN revision $Rev: 320 $
|
---|
8 | # Last update by $Author: kdeugau $
|
---|
9 | ###
|
---|
10 | # Copyright (C) 2004-2006 - Kris Deugau
|
---|
11 |
|
---|
12 | use DBI;
|
---|
13 | use MyIPDB;
|
---|
14 | use NetAddr::IP;
|
---|
15 |
|
---|
16 | ($dbh,$errstr) = connectDB_My;
|
---|
17 |
|
---|
18 | print "Content-type: text/plain\n\n";
|
---|
19 |
|
---|
20 | $tnumfree = $bigrfree = $bigufree = 0;
|
---|
21 |
|
---|
22 | $sql = 'select * from freeblocks where ';
|
---|
23 | # General counts first
|
---|
24 | if ($ARGV[0]) {
|
---|
25 | $sql .= 'maskbits >= $ARGV[0] and ';
|
---|
26 | }
|
---|
27 | $sql .= "not (cidr <<= '192.168.0.0/16') ".
|
---|
28 | "and not (cidr <<= '172.16.0.0/12') ".
|
---|
29 | "and not (cidr <<= '10.0.0.0/8') ";
|
---|
30 | $sql .= "order by maskbits desc";
|
---|
31 |
|
---|
32 | $sth = $dbh->prepare($sql);
|
---|
33 | $sth->execute;
|
---|
34 | while (@data = $sth->fetchrow_array) {
|
---|
35 | # cidr,maskbits,city,routed
|
---|
36 | $tnumfree++;
|
---|
37 | $numfree{"$data[1]"}++;
|
---|
38 | }
|
---|
39 |
|
---|
40 | print "Free block counts:\n";
|
---|
41 | foreach $size (sort {$a cmp $b} keys %numfree) {
|
---|
42 | print "/$size: $numfree{$size}\n";
|
---|
43 | }
|
---|
44 | print "\n";
|
---|
45 |
|
---|
46 | for ($i=30; $i>16; $i--) {
|
---|
47 | $j = $i-1;
|
---|
48 | $numfree{"$j"} += int $numfree{"$i"}/2;
|
---|
49 | $numfree{"$i"} -= (int $numfree{"$i"}/2)*2;
|
---|
50 | }
|
---|
51 |
|
---|
52 | print "Aggregate free space:\n";
|
---|
53 | foreach $size (sort {$a cmp $b} keys %numfree) {
|
---|
54 | print "/$size: $numfree{$size}\n";
|
---|
55 | }
|
---|