Scroll to navigation

REC_CONTROL(1) PowerDNS Recursor REC_CONTROL(1)

NAME

rec_control - Command line tool to control a running Recursor

SYNOPSIS

rec_control [OPTION]… COMMAND [COMMAND-OPTION]…

DESCRIPTION

rec_control allows the operator to query and control a running instance of the PowerDNS Recursor.

rec_control talks to the recursor via a the ‘controlsocket’. Which is usually located in /var/run . The –socket-dir or the –config-dir and –config-name switches control to which process rec_control connects.

EXAMPLES

To see if the Recursor is alive, run:

# rec_control ping


To stop the recursor by hand, run:

# rec_control quit


To dump the cache to disk, execute:

# rec_control dump-cache /tmp/the-cache


OPTIONS

provide this helpful message.
Directory where the recursor.conf lives.
Name of the virtual configuration.
Where the controlsocket will live, please use –config-dir instead.
When running in SMP mode, pid of pdns_recursor to control.
Number of seconds to wait for the remote PowerDNS Recursor to respond. Set to 0 for infinite.

COMMANDS

Add a Negative Trust Anchor for DOMAIN, suffixed optionally with REASON.
Add a Trust Anchor for DOMAIN with DS record data DSRECORD. This adds the new Trust Anchor to the existing set of Trust Anchors for DOMAIN.
Shows the currently active queries.
Remove Negative Trust Anchor for one or more DOMAINs. Set domain to ‘*’ to remove all NTA’s.
Remove Trust Anchor for one or more DOMAINs. Note that removing the root trust anchor is not possible.
Dumps the entire cache to FILENAME. This file should not exist already, PowerDNS will refuse to overwrite it. While dumping, the recursor will not answer questions.

Typical PowerDNS Recursors run multiple threads, therefore you’ll see duplicate, different entries for the same domains. The negative cache is also dumped to the same file. The per-thread positive and negative cache dumps are separated with an appropriate comment.

Dumps the EDNS status to the filename mentioned. This file should not exist already, PowerDNS will refuse to overwrite it. While dumping, the recursor will not answer questions.
Dumps the nameserver speed statistics to the FILENAME mentioned. This file should not exist already, PowerDNS will refuse to overwrite it. While dumping, the recursor will not answer questions. Statistics are kept per thread, and the dumps end up in the same file.
Dumps the content of the RPZ zone named ZONE NAME to the FILENAME mentioned. This file should not exist already, PowerDNS will refuse to overwrite it otherwise. While dumping, the recursor will not answer questions.
Retrieve a statistic. For items that can be queried, see ../metrics
Retrieve all known statistics.
Get a list of the currently configured Negative Trust Anchors.
Get a list of the currently configured Trust Anchors.
Retrieves the specified configuration parameter(s).
Retrieves QType statistics. Queries from cache aren’t being counted yet.
Shows a list of supported commands understood by the running pdns_recursor
Check if server is alive.
Request shutdown of the recursor.
quit-nicely
Request nice shutdown of the recursor.
Reloads ACLs.
(Re)loads Lua script FILENAME. If FILENAME is empty, attempt to reload the currently loaded script. This replaces the script currently loaded.
(Re)loads Lua configuration FILENAME. If FILENAME is empty, attempt to reload the currently loaded file. Note that FILENAME will be fully executed, any settings changed at runtime that are not modified in this file, will still be active. Reloading RPZ, especially by AXFR, can take some time; during which the recursor will not answer questions.
Reload authoritative and forward zones. Retains current configuration in case of errors.
Set the carbon-server setting to CARBON SERVER. If CARBON OURNAME is not empty, also set the carbon-ourname setting to CARBON OURNAME.
Set dnssec-log-bogus setting to SETTING. Set to ‘on’ or ‘yes’ to log DNSSEC validation failures and to ‘no’ or ‘off’ to disable logging these failures.
Change the maximum number of entries in the DNS cache. If reduced, the cache size will start shrinking to this number as part of the normal cache purging process, which might take a while.
Change the maximum number of entries in the packet cache. If reduced, the cache size will start shrinking to this number as part of the normal cache purging process, which might take a while.
Set minimum-ttl-override to NUM.
Shows the top-20 queries. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Shows the top-20 queries grouped by public suffix list. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Shows the top-20 remote hosts causing large answers. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Shows the top-20 most active remote hosts. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Shows the top-20 queries causing servfail responses. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Shows the top-20 queries causing servfail responses grouped by public suffix list. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Shows the top-20 most active remote hosts causing servfail responses. Statistics are over the last ‘stats-ringbuffer-entries’ queries.
Emit resolution trace for matching queries. Empty regex to disable trace.

Queries matching this regular expression will generate voluminous tracing output. Be aware that matches from the packet cache will still not generate tracing. To unset the regex, pass trace-regex without a new regex.

The regular expression is matched against domain queries terminated with a ‘.’. For example the regex ‘powerdns.com$’ will not match a query for ‘www.powerdns.com’, since the attempted match will be with ‘www.powerdns.com.’.

In addition, since this is a regular expression, to exclusively match queries for ‘www.powerdns.com’, one should escape the dots: ‘^www.powerdns.com.$’.

Multiple matches can be chained with the ‘|’ operator. For example, to match all queries for Dutch (.nl) and German (.de) domain names, use: ‘.nl.$|.de.$’.

Unloads Lua script if one was loaded.
Report running version.
Wipe entries for DOMAIN (exact name match) from the cache. This is useful if, for example, an important server has a new IP address, but the TTL has not yet expired. Multiple domain names can be passed. DOMAIN can be suffixed with a ‘$’. to delete the whole tree from the cache. i.e. ‘powerdns.com$’ will remove all cached entries under and including the powerdns.com name.

Note: this command also wipes the negative cache.

Warning: Don’t just wipe “www.somedomain.com”, its NS records or CNAME target may still be undesired, so wipe “somedomain.com” as well.


SEE ALSO

pdns_recursor(1)

AUTHOR

PowerDNS.COM BV

COPYRIGHT

2017, PowerDNS.COM BV

November 17, 2017 4.1