2017-01-12 04:02:45 +08:00
|
|
|
---
|
2017-10-11 20:33:17 +08:00
|
|
|
name: BIND
|
|
|
|
title: BIND Provider
|
2017-01-12 04:02:45 +08:00
|
|
|
layout: default
|
|
|
|
jsId: BIND
|
|
|
|
---
|
2017-10-11 20:33:17 +08:00
|
|
|
# BIND Provider
|
2017-10-11 23:59:29 +08:00
|
|
|
This provider maintains a directory with a collection of .zone files.
|
2017-03-23 00:38:08 +08:00
|
|
|
|
2017-10-12 00:02:40 +08:00
|
|
|
This provider does not generate or update the named.conf file, nor does it deploy the .zone files to the BIND master.
|
|
|
|
Both of those tasks are different at each site, so they are best done by a locally-written script.
|
|
|
|
|
|
|
|
|
2017-03-23 00:38:08 +08:00
|
|
|
## Configuration
|
2020-02-24 02:58:49 +08:00
|
|
|
The BIND provider does not require anything in `creds.json`. However
|
|
|
|
you can specify a `directory` where the provider will look for and create zone files. The default is the `zones` directory (in the current directory).
|
2017-09-13 22:00:41 +08:00
|
|
|
|
2017-10-11 23:59:29 +08:00
|
|
|
{% highlight json %}
|
2017-09-13 22:00:41 +08:00
|
|
|
{
|
2017-10-11 20:33:52 +08:00
|
|
|
"bind": {
|
2017-09-13 22:00:41 +08:00
|
|
|
"directory": "myzones"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
{% endhighlight %}
|
|
|
|
|
2020-02-24 02:58:49 +08:00
|
|
|
The BIND accepts some optional metadata via your DNS config when you create the provider:
|
|
|
|
|
|
|
|
In this example we set the default SOA settings and NS records.
|
2017-03-23 00:38:08 +08:00
|
|
|
|
|
|
|
{% highlight javascript %}
|
2017-10-11 20:33:52 +08:00
|
|
|
var BIND = NewDnsProvider('bind', 'BIND', {
|
|
|
|
'default_soa': {
|
|
|
|
'master': 'ns1.example.tld.',
|
|
|
|
'mbox': 'sysadmin.example.tld.',
|
|
|
|
'refresh': 3600,
|
|
|
|
'retry': 600,
|
|
|
|
'expire': 604800,
|
|
|
|
'minttl': 1440,
|
|
|
|
},
|
|
|
|
'default_ns': [
|
|
|
|
'ns1.example.tld.',
|
|
|
|
'ns2.example.tld.',
|
|
|
|
'ns3.example.tld.',
|
|
|
|
'ns4.example.tld.'
|
|
|
|
]
|
2017-03-23 00:38:08 +08:00
|
|
|
})
|
|
|
|
{% endhighlight %}
|
|
|
|
|
2020-02-24 03:47:14 +08:00
|
|
|
# FYI: get-zones
|
|
|
|
|
|
|
|
When used with "get-zones", specifying "all" scans the directory for
|
|
|
|
any files named `*.zone` and assumes they are zone files.
|
|
|
|
|
|
|
|
```
|
|
|
|
dnscontrol get-zones --format=nameonly - BIND all
|
|
|
|
```
|
|
|
|
|
|
|
|
# FYI: SOA Records
|
2020-02-24 02:58:49 +08:00
|
|
|
|
|
|
|
DNSControl assumes that SOA records are managed by the provider. Most
|
|
|
|
providers simply generate the SOA record for you and do not permit you
|
|
|
|
to control it at all. The BIND provider is unique in that it must emulate
|
|
|
|
what most DNS-as-a-service providers do.
|
|
|
|
|
|
|
|
When DNSControl reads a BIND zonefile:
|
|
|
|
|
|
|
|
* If there was no SOA record, one is created using the `default_soa`
|
|
|
|
settings listed above.
|
|
|
|
* When generating a new zonefile, the SOA serial number is
|
|
|
|
updated.
|
|
|
|
|
2020-05-22 22:20:10 +08:00
|
|
|
DNSControl tries to maintain the serial number as yyyymmddvv. If the
|
2020-02-24 02:58:49 +08:00
|
|
|
existing serial number is significantly higher it will simply
|
|
|
|
increment the value by 1.
|
|
|
|
|
|
|
|
If you need to edit the SOA fields, the best way is to edit the
|
|
|
|
zonefile directly, then run `dnscontrol preview` and `dnscontrol push`
|
|
|
|
as normal.
|