NAME

AnyEvent::DNS::Cache::Simple - Simple cache for AnyEvent::DNS

SYNOPSIS

use AnyEvent::DNS::Cache::Simple;

my $guard = AnyEvent::DNS::Cache::Simple->register(
    ttl => 60,
    negative_ttl => 5,
    timeout => [1,1]
);

for my $i ( 1..3 ) {
    my $cv = AE::cv;
    AnyEvent::DNS::a "example.com", sub {
        say join " | ",@_;
        $cv->send;
    };
    $cv->recv;
}

undef $guard;

DESCRIPTION

AnyEvent::DNS::Cache::Simple provides simple cache capability for AnyEvent::DNS

CPAN already has AnyEvent::CacheDNS module. It also provides simple cache. AnyEvent::DNS::Cache::Simple support ttl, negative_ttl and can use with any cache module. And AnyEvent::DNS::Cache::Simple does not use AnyEvent->timer for purging cache.

METHOD

register

Register cache to $AnyEvent::DNS::RESOLVER. This method returns guard object. If the guard object is destroyed, original resolver will be restored

register can accept all AnyEvent::DNS-new> arguments and has some additional arguments.

ttl: Int

maximum positive cache ttl in seconds. (default: 5)

negative_ttl: Int

negative cache ttl in seconds. (default: 1)

cache: Object

Cache object, requires support get, set and remove methods. default: Cache::Memory::Simple is used

SEE ALSO

AnyEvent::DNS, AnyEvent::Socket, AnyEvent::CacheDNS, Cache::Memory::Simple

LICENSE

Copyright (C) Masahiro Nagano.

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

AUTHOR

Masahiro Nagano <kazeburo@gmail.com>