… | |
… | |
193 | sub DESTROY { |
193 | sub DESTROY { |
194 | #my $self = shift; |
194 | #my $self = shift; |
195 | $::conns--; |
195 | $::conns--; |
196 | } |
196 | } |
197 | |
197 | |
|
|
198 | sub prune_cache { |
|
|
199 | my $hash = $_[0]; |
|
|
200 | |
|
|
201 | for (keys %$hash) { |
|
|
202 | if (ref $hash->{$_} eq HASH::) { |
|
|
203 | prune_cache($hash->{$_}); |
|
|
204 | unless (scalar keys %{$hash->{$_}}) { |
|
|
205 | delete $hash->{$_}; |
|
|
206 | $d2++; |
|
|
207 | } |
|
|
208 | } |
|
|
209 | } |
|
|
210 | } |
|
|
211 | |
|
|
212 | sub prune_caches { |
|
|
213 | prune_cache \%conn; |
|
|
214 | prune_cache \%uri; |
|
|
215 | |
|
|
216 | for (keys %blocked) { |
|
|
217 | delete $blocked{$_} if $blocked{$_}[0] > $::NOW; |
|
|
218 | } |
|
|
219 | } |
|
|
220 | |
|
|
221 | Event->timer(interval => 60, cb => \&prune_caches); |
|
|
222 | |
198 | sub slog { |
223 | sub slog { |
199 | my $self = shift; |
224 | my $self = shift; |
200 | main::slog($_[0], "$self->{remote_id}> $_[1]"); |
225 | main::slog($_[0], "$self->{remote_id}> $_[1]"); |
201 | } |
226 | } |
202 | |
227 | |