説明
recursorは定義されたIPアドレスを使用してドメインを解決するか、定義されたレゾルバを使用してマップされた他のドメインを解決します。
構文
recursor {
[external-yaml config-file-path]
[external-json config-file-path]
[verbose 0..2]
zone: zone.name
[resolver non-default {
urls udp://ip-1:port udp://ip-n:port
[timeout_ms 500]
}]
[alias alias-name | * {
[hosts domain-1 domain-n]
[ips ip-1 ip-n]
[resolver_name non-default]
[ttl custom-ttl]
}]
}
recursor
の定義
zone
- recursorのDNSゾーンverbose
- stdoutログレベル0
- 最小1
- 中間2
- 詳細
resolvers
- 他のDNSサーバー- マッピングキー/id: レゾルバの名前、
default
はシステムのデフォルトレゾルバをオーバーライドします urls
: URLアドレスのリスト、例:udp://127.0.0.1:53
(システムのデフォルトは://default
で表されます)timeout_ms
: ミリ秒単位のレゾルバの接続タイムアウト
- マッピングキー/id: レゾルバの名前、
aliases
- ドメインエイリアス- マッピングキー/id: エイリアスの名前、サブドメイン、またはrecursorのDNSリピータにしたい場合は
*
ips
: 応答の一部として返すIPアドレスhosts
: この方法で取得したIPアドレスが応答の一部として返されるように、解決するドメインresolver_name
: 現在のレゾルバの参照、デフォルトはもちろんです...default
:)ttl
: 秒単位のDNSレコードの有効期限
- マッピングキー/id: エイリアスの名前、サブドメイン、またはrecursorのDNSリピータにしたい場合は
メトリクス
監視が有効になっている場合 (prometheusディレクティブを通じて)次のメトリクスがエクスポートされます。
ヘルス
このプラグインは動的なヘルスチェックを実装しています。ただし、常に正常を返します。
例
Corefile
recursor {
[external-yaml config-file-path]
[external-json config-file-path]
[verbose 0..2]
zone: demo.svc
resolver dns-c {
urls udp://1.1.1.1:53 udp://1.0.0.1:53
timeout_ms 500
}
resolver dns-g {
urls udp://8.8.8.8:53 udp://8.8.4.4:53
}
resolver demo {
urls udp://10.0.0.1:53
}
alias alias1 {
hosts www.example.org www.example.com
resolver_name dns-c
ttl 11
}
alias alias2 {
ips 10.0.0.1 10.0.0.2
ttl 12
}
alias alias3 {
ips 10.0.0.1 10.0.0.2
hosts www.example.net
resolver_name dns-g
ttl 13
}
alias alias4 {
hosts www.example.net
ttl 14
}
alias * {
resolver_name demo
ttl 15
}
}
外部YAML
zone: demo.svc
resolvers:
dns-c:
urls: [ udp://1.1.1.1:53, udp://1.0.0.1:53 ]
timeout_ms: 500
dns-g:
urls: [ udp://8.8.8.8:53, udp://8.8.4.4:53 ]
demo:
urls: [ udp://10.0.0.1:53 ]
aliases:
alias1:
hosts: [ www.example.org, www.example.com ]
resolver_name: dns-c
ttl: 11
alias2:
ips: [ 10.0.0.1, 10.0.0.2 ]
ttl: 12
alias3:
ips: [ 10.0.0.1, 10.0.0.2 ]
hosts: [ www.example.net ]
resolver_name: dns-g
ttl: 13
alias4:
hosts: [ www.example.net ]
ttl: 14
"*":
resolver_name: demo
ttl: 15
外部JSON
{
"zone": "demo.svc",
"resolvers": {
"dns-c": {
"urls": [ "udp://1.1.1.1:53", "udp://1.0.0.1:53" ],
"timeout_ms": 500
},
"dns-g": {
"urls": [ "udp://8.8.8.8:53", "udp://8.8.4.4:53" ]
},
"demo": {
"urls": [ "udp://10.0.0.1:53" ]
}
},
"aliases": {
"alias1": {
"hosts": [ "www.example.org", "www.example.com" ],
"resolver_name": "dns-c",
"ttl": 11
},
"alias2": {
"ips": [ "10.0.0.1", "10.0.0.2" ],
"ttl": 12
},
"alias3": {
"ips": [ "10.0.0.1", "10.0.0.2" ],
"hosts": [ "www.example.net" ],
"resolver_name": "dns-g",
"ttl": 13
},
"alias4": {
"hosts": [ "www.example.net" ],
"ttl": 14
},
"*": {
"resolver_name": "demo",
"ttl": 15
}
}
}
こちらもご覧ください
マニュアルを参照してください。