| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | # file
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-04 12:53:07 +00:00
										 |  |  | ## Name
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | *file* - enables serving zone data from an RFC 1035-style master file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Description
 | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-04 06:56:37 +01:00
										 |  |  | The *file* plugin is used for an "old-style" DNS server. It serves from a preloaded file that exists | 
					
						
							| 
									
										
										
										
											2021-03-08 12:15:20 +01:00
										 |  |  | on disk contained RFC 1035 styled data. If the zone file contains signatures (i.e., is signed using | 
					
						
							|  |  |  | DNSSEC), correct DNSSEC answers are returned. Only NSEC is supported! If you use this setup *you* | 
					
						
							|  |  |  | are responsible for re-signing the zonefile. | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ## Syntax
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ~~~ | 
					
						
							| 
									
										
										
										
											2016-10-10 20:13:22 +01:00
										 |  |  | file DBFILE [ZONES...] | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | ~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 11:57:39 -08:00
										 |  |  | * **DBFILE** the database file to read and parse. If the path is relative, the path from the *root* | 
					
						
							| 
									
										
										
										
											2019-10-08 10:20:48 +01:00
										 |  |  |   plugin will be prepended to it. | 
					
						
							| 
									
										
										
										
											2016-10-10 20:13:22 +01:00
										 |  |  | * **ZONES** zones it should be authoritative for. If empty, the zones from the configuration block | 
					
						
							| 
									
										
										
										
											2019-10-08 10:20:48 +01:00
										 |  |  |   are used. | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 11:57:39 -08:00
										 |  |  | If you want to round-robin A and AAAA responses look at the *loadbalance* plugin. | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ~~~ | 
					
						
							| 
									
										
										
										
											2016-10-10 20:13:22 +01:00
										 |  |  | file DBFILE [ZONES... ] { | 
					
						
							| 
									
										
										
										
											2018-09-29 17:50:49 +02:00
										 |  |  |     reload DURATION | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | } | 
					
						
							|  |  |  | ~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 11:57:39 -08:00
										 |  |  | * `reload` interval to perform a reload of the zone if the SOA version changes. Default is one minute. | 
					
						
							|  |  |  |   Value of `0` means to not scan for changes and reload. For example, `30s` checks the zonefile every 30 seconds | 
					
						
							|  |  |  |   and reloads the zone when serial changes. | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-24 11:30:39 -07:00
										 |  |  | If you need outgoing zone transfers, take a look at the *transfer* plugin. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-27 07:37:23 +01:00
										 |  |  | ## Examples
 | 
					
						
							| 
									
										
										
										
											2016-04-03 09:02:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 12:15:20 +01:00
										 |  |  | Load the `example.org` zone from `db.example.org` and allow transfers to the internet, but send | 
					
						
							| 
									
										
										
										
											2016-09-18 09:32:06 +01:00
										 |  |  | notifies to 10.240.1.1 | 
					
						
							| 
									
										
										
										
											2016-04-03 09:02:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 11:47:55 +00:00
										 |  |  | ~~~ corefile | 
					
						
							| 
									
										
										
										
											2017-10-31 07:14:49 +00:00
										 |  |  | example.org { | 
					
						
							| 
									
										
										
										
											2021-03-08 12:15:20 +01:00
										 |  |  |     file db.example.org | 
					
						
							| 
									
										
										
										
											2020-09-24 11:30:39 -07:00
										 |  |  |     transfer { | 
					
						
							|  |  |  |         to * 10.240.1.1 | 
					
						
							| 
									
										
										
										
											2017-10-31 07:14:49 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | ~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 12:15:20 +01:00
										 |  |  | Where `db.example.org` would contain RRSets (<https://tools.ietf.org/html/rfc7719#section-4>) in the | 
					
						
							|  |  |  | (text) presentation format from RFC 1035: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ~~~ | 
					
						
							|  |  |  | $ORIGIN example.org. | 
					
						
							|  |  |  | @	3600 IN	SOA sns.dns.icann.org. noc.dns.icann.org. 2017042745 7200 3600 1209600 3600 | 
					
						
							|  |  |  | 	3600 IN NS a.iana-servers.net. | 
					
						
							|  |  |  | 	3600 IN NS b.iana-servers.net. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | www     IN A     127.0.0.1 | 
					
						
							|  |  |  |         IN AAAA  ::1 | 
					
						
							|  |  |  | ~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-31 07:14:49 +00:00
										 |  |  | Or use a single zone file for multiple zones: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 11:47:55 +00:00
										 |  |  | ~~~ corefile | 
					
						
							| 
									
										
										
										
											2017-10-31 07:14:49 +00:00
										 |  |  | . { | 
					
						
							| 
									
										
										
										
											2020-09-24 11:30:39 -07:00
										 |  |  |     file example.org.signed example.org example.net | 
					
						
							|  |  |  |     transfer example.org example.net { | 
					
						
							|  |  |  |         to * 10.240.1.1 | 
					
						
							| 
									
										
										
										
											2017-10-31 07:14:49 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-04-03 09:02:34 +01:00
										 |  |  | } | 
					
						
							|  |  |  | ~~~ | 
					
						
							| 
									
										
										
										
											2019-06-17 19:47:07 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Note that if you have a configuration like the following you may run into a problem of the origin | 
					
						
							|  |  |  | not being correctly recognized: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 11:47:55 +00:00
										 |  |  | ~~~ corefile | 
					
						
							| 
									
										
										
										
											2019-06-17 19:47:07 +01:00
										 |  |  | . { | 
					
						
							|  |  |  |     file db.example.org | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | ~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | We omit the origin for the file `db.example.org`, so this references the zone in the server block, | 
					
						
							|  |  |  | which, in this case, is the root zone. Any contents of `db.example.org` will then read with that | 
					
						
							|  |  |  | origin set; this may or may not do what you want. | 
					
						
							| 
									
										
										
										
											2019-06-17 15:46:02 -04:00
										 |  |  | It's better to be explicit here and specify the correct origin. This can be done in two ways: | 
					
						
							| 
									
										
										
										
											2019-06-17 19:47:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 11:47:55 +00:00
										 |  |  | ~~~ corefile | 
					
						
							| 
									
										
										
										
											2019-06-17 19:47:07 +01:00
										 |  |  | . { | 
					
						
							|  |  |  |     file db.example.org example.org | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | ~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Or | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-27 11:47:55 +00:00
										 |  |  | ~~~ corefile | 
					
						
							| 
									
										
										
										
											2019-06-17 19:47:07 +01:00
										 |  |  | example.org { | 
					
						
							|  |  |  |     file db.example.org | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | ~~~ | 
					
						
							| 
									
										
										
										
											2019-07-04 06:56:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-28 18:56:35 +01:00
										 |  |  | ## See Also
 | 
					
						
							| 
									
										
										
										
											2019-07-04 06:56:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-24 11:30:39 -07:00
										 |  |  | See the *loadbalance* plugin if you need simple record shuffling. And the *transfer* plugin for zone | 
					
						
							| 
									
										
										
										
											2021-03-08 12:15:20 +01:00
										 |  |  | transfers. Lastly the *root* plugin can help you specify the location of the zone files. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | See [RFC 1035](https://www.rfc-editor.org/rfc/rfc1035.txt) for more info on how to structure zone | 
					
						
							|  |  |  | files. |