DNS » History » Version 4
Marc Dequènes, 2018-05-04 16:54
1 | 1 | Marc Dequènes | h1. DNS |
---|---|---|---|
2 | |||
3 | h2. Zone Management |
||
4 | |||
5 | On each DNS server, master zone can be created/updated on _/etc/bind/masters/_. The ownership needs to be: |
||
6 | * _banya:_ if a user zone which should be updatable via the Banya service |
||
7 | * _root:bind_ in all other cases |
||
8 | |||
9 | The zone is declared in _host_vars/_dnsserver_/dns.yml_ and the playbook _playbooks/tenants/duckcorp/dns.yml_ is in charge of updating all configurations. Only the zone content is not Ansible managed. |
||
10 | |||
11 | 2 | Marc Dequènes | Better to check the file validity before updating the zone: |
12 | <pre> |
||
13 | named-checkzone <zone-name> <zone-file> |
||
14 | </pre> |
||
15 | |||
16 | Then to update the zone, if DNSSEC-signed: |
||
17 | <pre> |
||
18 | ods-signer sign <zone-name> |
||
19 | </pre> |
||
20 | else: |
||
21 | <pre> |
||
22 | rndc reload <zone-name> |
||
23 | </pre> |
||
24 | |||
25 | In case the zone is DNSSEC-signed, the publishing of keys in the parent zone is to be done manually (not automated yet); more details below. |
||
26 | 1 | Marc Dequènes | |
27 | h2. Secure Zone Transfers |
||
28 | |||
29 | To secure zone transfers, a TSIG key needs to be created and added on both sides. Beware the key name *must* be identical on both side. |
||
30 | |||
31 | DNS server groups (servers allowed to request transfer) and keys can be defined in _host_vars/<dnsserver>/dns.yml_ and _host_vars/<dnsserver>/dns.vault.yml_ respectively. If they are to be used on all servers, then you can declare them in _group_vars/dns_servers/dns.yml_ and _group_vars/dns_servers/dns.vault.yml_ respectively. |
||
32 | |||
33 | You can a new key using: |
||
34 | <pre> |
||
35 | dnssec-keygen -a HMAC-SHA512 -b 512 -n HOST taiste |
||
36 | </pre> |
||
37 | Take the 'Key' part in 'Ktaiste.*.private' file, to put into the configuration. |
||
38 | |||
39 | The same playbook (_playbooks/tenants/duckcorp/dns.yml_) is used to update the configuration. |
||
40 | |||
41 | h2. DNSSEC |
||
42 | |||
43 | 3 | Marc Dequènes | h3. Introduction |
44 | |||
45 | Better read some documentation before fiddling with the controls: |
||
46 | * "Supported rollover methods with OpenDNSSEC":https://wiki.opendnssec.org/display/DOCS/Key+Rollovers |
||
47 | * "Explanation about the OpenDNSSEC key states":https://wiki.opendnssec.org/display/DOCS/Key+States |
||
48 | * "Deeper explanation about the OpenDNSSEC key states":https://wiki.opendnssec.org/display/DOCS20/Key+States+Explained |
||
49 | |||
50 | List of keys with states and IDs: |
||
51 | <pre> |
||
52 | ods-enforcer key list -v |
||
53 | </pre> |
||
54 | |||
55 | List of planned rollover dates: |
||
56 | <pre> |
||
57 | ods-enforcer rollover list |
||
58 | </pre> |
||
59 | |||
60 | h3. Key Rollover |
||
61 | |||
62 | The ZSK key rollover is handled automatically by OpenDNSSEC, so admins have nothing to do. |
||
63 | |||
64 | The KSK rollover implies contact with the parent zone and a manual step to get the DS entry in their zone is needed. |
||
65 | |||
66 | h3. KSK Rollover Workflow |
||
67 | |||
68 | Here are the states and what needs to be done: |
||
69 | * *publish* state: |
||
70 | ** when a new key is created, either for a new zone of to replace an old key, this key is added to the zone but not used to sign yet |
||
71 | ** action: wait |
||
72 | * *ready* state: |
||
73 | ** the new zone, containing the key, is considered propagated, but not used to sign yet |
||
74 | 4 | Marc Dequènes | ** action: export the key, either using the DNSKEY or DS format depending on the provider (*ods-enforcer key export -z <zone-name> --keytype KSK --keystate ready* for the DNSKEY, or add *--ds* for the DS) |
75 | ** action: add the key to the parent zone |
||
76 | 1 | Marc Dequènes | ** action: wait for the key to appear in the parent zone (*host -t DS -r <zone-name> $(host -t NS <tld> | grep "name server" | head -n 1 | cut -d" " -f4)*) |
77 | 4 | Marc Dequènes | ** action: notify OpenDNSSEC (*ods-enforcer key ds-seen -z <zone-name> --cka_id <key-id>*) |
78 | * *active* state: |
||
79 | ** the key is used for signing |
||
80 | ** action: wait for the next rollover |
||
81 | * *retire* state: |
||
82 | ** the key is no more used to sign but still advertized |
||
83 | ** action: remove the key from the parent zone |
||
84 | ** action: wait for the key to disappear from the parent zone (*host -t DS -r <zone-name> $(host -t NS <tld> | grep "name server" | head -n 1 | cut -d" " -f4)*) |
||
85 | ** action: notify OpenDNSSEC (*ods-enforcer key ds-gone -z <zone-name> --cka_id <key-id>*) |
||
86 | ** action: purge old keys (*ods-enforcer key purge --policy default*) |
||
87 | 3 | Marc Dequènes | |
88 | 1 | Marc Dequènes | TODO |