Konfigurationsdatei
In der Datei config.dist.yml
finden Sie ein vollständiges Beispiel für eine YAML-Konfigurationsdatei mit Kommentaren.
dns
Das Objekt dns
konfiguriert das Verhalten des DNS-Servers. Es hat folgende Eigenschaften:
cache
Das Objekt cache
konfiguriert das Zwischenspeichern der Ergebnisse von DNS-Abfragen. Es hat folgende Eigenschaften:
enabled
: Legt fest, ob die DNS-Ergebnisse zwischengespeichert werden sollen oder nicht.Beispiel:
true
size
: Die maximale Größe des DNS-Ergebnis-Caches als für den Nutzer erfassbare Datengröße. Sie muss größer als Null sein, wennenabled
auftrue
steht.Example:
128MB
client_size
: Die maximale Größe des DNS-Ergebnis-Caches für die Adresse oder das Subnetz eines jeden konfigurierten Clients in Form von für den Nutzer erfassbaren Daten. Sie muss größer als Null sein, wennenabled
auftrue
steht.Example:
4MB
server
Das Objekt server
konfiguriert die Verarbeitung der eingehenden Anfragen. Es hat folgende Eigenschaften:
listen_addresses
: Die Menge der Adressen mit den zu überwachenden Ports.Eigenschaftsbeispiel:
'listen_addresses':
- address: '127.0.0.1:53'
- address: '[::1]:53'
bootstrap
Das Objekt bootstrap
konfiguriert die Auflösung von upstream Serveradressen. Es hat folgende Eigenschaften:
servers
: Die Liste der Server, die die Hostnamen der Upstream-Server auflösen.Eigenschaftsbeispiel:
'servers':
- address: '8.8.8.8:53'
- address: '192.168.1.1:53'timeout
: Die Zeitüberschreitung für Bootstrap-DNS-Anfragen in einer für den Nutzer erfassbaren Dauer.Beispiel:
2s
upstream
Das Objekt upstream
konfiguriert die eigentliche Auflösung von Anfragen. Es hat folgende Eigenschaften:
groups
: Die Gruppe von Upstream-Servern, die durch den Gruppennamen gekennzeichnet sind. Es enthält die folgenden Felder:address
: Die Adresse des Upstream-Servers.Beispiel:
'8.8.8.8:53'
match
: Die Liste der Kriterien, mit denen die Anfrage abgeglichen werden soll. Jeder Eintrag kann die folgenden Eigenschaften enthalten:question_domain
: Die Domain oder ein Suffix der Domain, die von der Gruppe der Upstream-Server aufgelöst werden soll.Beispiel:
'mycompany.local'
client
: Die Adresse des Clients oder ein Teilnetz der Adresse des Clients, von dem aus die Gruppe der Upstream-Server Anfragen auflösen soll. Sie darf keine signifikanten Bits außerhalb der Subnetzmaske haben.Beispiel:
'192.0.2.0/24'
noteDie in einem einzigen Eintrag angegebenen Eigenschaften werden mit einem logischen UND verknüpft. Die Eingaben werden mit einem logischen ODER kombiniert.
Eigenschaftsbeispiel:
'match':
- question_domain: 'mycompany.local'
client: '192.168.1.0/24'
- question_domain: 'mycompany.external'
- client: '1.2.3.4'
infogroups
sollte mindestens einen einzelnen Eintrag namensdefault
und optional einen einzelnen Eintrag namensprivate
enthalten, beide sollten keinematch
Eigenschaft haben.Die Gruppe
default
wird verwendet, wenn es keine Übereinstimmung mit anderen Gruppen gibt. Die Gruppeprivate
wird verwendet, um die PTR-Anfragen für die privaten IP-Adressen aufzulösen. Solche Abfragen werden mitNXDOMAIN
beantwortet, wenn keine Gruppeprivate
definiert ist.timeout
: Die Zeitüberschreitung für vorgelagerte DNS-Anfragen in einer für den Nutzer erfassbaren Dauer.Beispiel:
2s
fallback
Das Objekt fallback
konfiguriert das Verhalten des DNS-Servers im Falle eines Fehlers. Es hat folgende Eigenschaften:
server
: Die Liste der Server, die verwendet werden sollen, nachdem der eigentliche upstream nicht geantwortet hat.Eigenschaftsbeispiel:
'servers':
- address: 'tls://94.140.14.140'timeout
: Die Zeitüberschreitung für Fallback-DNS-Anfragen in einer für den Nutzer erfassbaren Dauer.Beispiel:
2s
debug
Das Objekt debug
konfiguriert die Debugging-Funktionen. Es hat folgende Eigenschaften:
pprof
Das Objekt pprof
konfiguriert die pprof
HTTP-Handler. Es hat folgende Eigenschaften:
port
: Der Port, der auf Debug-HTTP-Anfragen auf localhost überwacht werden soll.Beispiel:
6060
enabled
: Gibt an, ob die Debug-Profilerstellung aktiviert ist oder nicht.Beispiel:
true
log
Das Objekt log
konfiguriert die Protokollierung. Es hat folgende Eigenschaften:
output
: Die Ausgabe, in die die Protokolle geschrieben werden.noteProtokolleinträge, die in das Systemprotokoll geschrieben werden, haben das Format
text
(siehe unten) und verwenden den Zeitstempel des Systems.Mögliche Werte:
syslog
bedeutet, dass das plattformspezifische Systemprotokoll verwendet wird, d. h. „syslog“ für Linux und „Ereignisprotokoll“ für Windows.stdout
für Standard-Ausgabe-Stream.stderr
für den Standard-Fehler-Stream.Absoluter Pfad zur Protokolldatei.
Beispiel:
/home/user/logs
Beispiel:
C:\Users\user\logs.txt
Beispiel:
syslog
format
: Gibt das Format der Protokolleinträge an.Mögliche Werte:
default
: Ein einfaches Format. Beispiel:INFO service started prefix=program addr=127.0.0.1:53
json
: Ein strukturiertes JSON-Format. Beispiel:{"level":"INFO","msg":"service started","prefix":"program","addr":"127.0.0.1:53"}
jsonhybrid
: Identisch mitjson
, aber mit einer begrenzten Anzahl von Feldern. Beispiel:{"level":"INFO","msg":"service started, attrs: prefix=program addr=127.0.0.1:53"}
text
: Ein strukturiertes Textformat. Beispiel:level=INFO msg="service started" prefix=program addr=127.0.0.1:53
Standard:
default
timestamp
: Gibt an, ob ein Zeitstempel in die Protokolleinträge aufgenommen werden soll.Beispiel:
false
verbose
: Gibt an, ob das Protokoll mehr Informationen enthalten soll.Beispiel:
false