mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-03 01:17:45 +03:00
resolved: include DNS server feature level info in SIGUSR1 status dump
let's make the status dump more useful for tracking down server issues.
This commit is contained in:
parent
d55b0463b2
commit
cf84484a56
7
NEWS
7
NEWS
@ -213,7 +213,12 @@ CHANGES WITH 235:
|
|||||||
switch. When invoked like this systemd-resolved will forget
|
switch. When invoked like this systemd-resolved will forget
|
||||||
everything it learnt about the features supported by the configured
|
everything it learnt about the features supported by the configured
|
||||||
upstream DNS servers, and restarts the feature probing logic on the
|
upstream DNS servers, and restarts the feature probing logic on the
|
||||||
next resolver look-up for them at the highest feature level again.
|
next resolver look-up for them at the highest feature level
|
||||||
|
again.
|
||||||
|
|
||||||
|
* The status dump systemd-resolved sends to the logs upon receiving
|
||||||
|
SIGUSR1 now also includes information about all DNS servers it is
|
||||||
|
configured to use, and the features levels it probed for them.
|
||||||
|
|
||||||
Contributions from: Abdó Roig-Maranges, Alan Jenkins, Alexander
|
Contributions from: Abdó Roig-Maranges, Alan Jenkins, Alexander
|
||||||
Kuleshov, Andreas Rammhold, Andrew Jeddeloh, Andrew Soutar, Ansgar
|
Kuleshov, Andreas Rammhold, Andrew Jeddeloh, Andrew Soutar, Ansgar
|
||||||
|
@ -203,8 +203,9 @@
|
|||||||
<term><constant>SIGUSR1</constant></term>
|
<term><constant>SIGUSR1</constant></term>
|
||||||
|
|
||||||
<listitem><para>Upon reception of the <constant>SIGUSR1</constant> process signal
|
<listitem><para>Upon reception of the <constant>SIGUSR1</constant> process signal
|
||||||
<command>systemd-resolved</command> will dump the contents of all DNS resource record caches it maintains into
|
<command>systemd-resolved</command> will dump the contents of all DNS resource record caches it maintains, as
|
||||||
the system logs.</para></listitem>
|
well as all feature level information it learnt about configured DNS servers into the system
|
||||||
|
logs.</para></listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
|
@ -853,6 +853,57 @@ void dns_server_reset_features_all(DnsServer *s) {
|
|||||||
dns_server_reset_features(i);
|
dns_server_reset_features(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dns_server_dump(DnsServer *s, FILE *f) {
|
||||||
|
assert(s);
|
||||||
|
|
||||||
|
if (!f)
|
||||||
|
f = stdout;
|
||||||
|
|
||||||
|
fputs("[Server ", f);
|
||||||
|
fputs(dns_server_string(s), f);
|
||||||
|
fputs(" type=", f);
|
||||||
|
fputs(dns_server_type_to_string(s->type), f);
|
||||||
|
|
||||||
|
if (s->type == DNS_SERVER_LINK) {
|
||||||
|
assert(s->link);
|
||||||
|
|
||||||
|
fputs(" interface=", f);
|
||||||
|
fputs(s->link->name, f);
|
||||||
|
}
|
||||||
|
|
||||||
|
fputs("]\n", f);
|
||||||
|
|
||||||
|
fputs("\tVerified feature level: ", f);
|
||||||
|
fputs(strna(dns_server_feature_level_to_string(s->verified_feature_level)), f);
|
||||||
|
fputc('\n', f);
|
||||||
|
|
||||||
|
fputs("\tPossible feature level: ", f);
|
||||||
|
fputs(strna(dns_server_feature_level_to_string(s->possible_feature_level)), f);
|
||||||
|
fputc('\n', f);
|
||||||
|
|
||||||
|
fputs("\tDNSSEC Mode: ", f);
|
||||||
|
fputs(strna(dnssec_mode_to_string(dns_server_get_dnssec_mode(s))), f);
|
||||||
|
fputc('\n', f);
|
||||||
|
|
||||||
|
fputs("\tCan do DNSSEC: ", f);
|
||||||
|
fputs(yes_no(dns_server_dnssec_supported(s)), f);
|
||||||
|
fputc('\n', f);
|
||||||
|
|
||||||
|
fprintf(f,
|
||||||
|
"\tMaximum UDP packet size received: %zu\n"
|
||||||
|
"\tFailed UDP attempts: %u\n"
|
||||||
|
"\tFailed TCP attempts: %u\n"
|
||||||
|
"\tSeen truncated packet: %s\n"
|
||||||
|
"\tSeen OPT RR getting lost: %s\n"
|
||||||
|
"\tSeen RRSIG RR missing: %s\n",
|
||||||
|
s->received_udp_packet_max,
|
||||||
|
s->n_failed_udp,
|
||||||
|
s->n_failed_tcp,
|
||||||
|
yes_no(s->packet_truncated),
|
||||||
|
yes_no(s->packet_bad_opt),
|
||||||
|
yes_no(s->packet_rrsig_missing));
|
||||||
|
}
|
||||||
|
|
||||||
static const char* const dns_server_type_table[_DNS_SERVER_TYPE_MAX] = {
|
static const char* const dns_server_type_table[_DNS_SERVER_TYPE_MAX] = {
|
||||||
[DNS_SERVER_SYSTEM] = "system",
|
[DNS_SERVER_SYSTEM] = "system",
|
||||||
[DNS_SERVER_FALLBACK] = "fallback",
|
[DNS_SERVER_FALLBACK] = "fallback",
|
||||||
|
@ -154,3 +154,5 @@ void dns_server_flush_cache(DnsServer *s);
|
|||||||
|
|
||||||
void dns_server_reset_features(DnsServer *s);
|
void dns_server_reset_features(DnsServer *s);
|
||||||
void dns_server_reset_features_all(DnsServer *s);
|
void dns_server_reset_features_all(DnsServer *s);
|
||||||
|
|
||||||
|
void dns_server_dump(DnsServer *s, FILE *f);
|
||||||
|
@ -519,8 +519,11 @@ static int manager_sigusr1(sd_event_source *s, const struct signalfd_siginfo *si
|
|||||||
_cleanup_free_ char *buffer = NULL;
|
_cleanup_free_ char *buffer = NULL;
|
||||||
_cleanup_fclose_ FILE *f = NULL;
|
_cleanup_fclose_ FILE *f = NULL;
|
||||||
Manager *m = userdata;
|
Manager *m = userdata;
|
||||||
|
DnsServer *server;
|
||||||
size_t size = 0;
|
size_t size = 0;
|
||||||
DnsScope *scope;
|
DnsScope *scope;
|
||||||
|
Iterator i;
|
||||||
|
Link *l;
|
||||||
|
|
||||||
assert(s);
|
assert(s);
|
||||||
assert(si);
|
assert(si);
|
||||||
@ -533,6 +536,14 @@ static int manager_sigusr1(sd_event_source *s, const struct signalfd_siginfo *si
|
|||||||
LIST_FOREACH(scopes, scope, m->dns_scopes)
|
LIST_FOREACH(scopes, scope, m->dns_scopes)
|
||||||
dns_scope_dump(scope, f);
|
dns_scope_dump(scope, f);
|
||||||
|
|
||||||
|
LIST_FOREACH(servers, server, m->dns_servers)
|
||||||
|
dns_server_dump(server, f);
|
||||||
|
LIST_FOREACH(servers, server, m->fallback_dns_servers)
|
||||||
|
dns_server_dump(server, f);
|
||||||
|
HASHMAP_FOREACH(l, m->links, i)
|
||||||
|
LIST_FOREACH(servers, server, l->dns_servers)
|
||||||
|
dns_server_dump(server, f);
|
||||||
|
|
||||||
if (fflush_and_check(f) < 0)
|
if (fflush_and_check(f) < 0)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user