mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-31 10:13:14 -04:00 
			
		
		
		
	* Implement notifies for transfer plugin (#3972) * Fix notifies in transfer plugin Signed-off-by: Miek Gieben <miek@miek.nl> * Make it compile Signed-off-by: Miek Gieben <miek@miek.nl> * Port more plugins Signed-off-by: Miek Gieben <miek@miek.nl> * golint Signed-off-by: Miek Gieben <miek@miek.nl> * Fix tests Signed-off-by: Miek Gieben <miek@miek.nl> * Fix notifies in transfer plugin Signed-off-by: Miek Gieben <miek@miek.nl> * Make it compile Signed-off-by: Miek Gieben <miek@miek.nl> * Port more plugins Signed-off-by: Miek Gieben <miek@miek.nl> * golint Signed-off-by: Miek Gieben <miek@miek.nl> * Fix tests Signed-off-by: Miek Gieben <miek@miek.nl> * Fix tests Signed-off-by: Miek Gieben <miek@miek.nl> * really fix test Signed-off-by: Miek Gieben <miek@miek.nl> * Implement ixfr fallback and unify file and auto for transfering Signed-off-by: Miek Gieben <miek@miek.nl> * Add transfer tests copied and modified from #3452 Signed-off-by: Miek Gieben <miek@miek.nl> * Test correct selection of plugin Signed-off-by: Miek Gieben <miek@miek.nl> * add upstream back in Signed-off-by: Miek Gieben <miek@miek.nl> * Implement ixfr fallback and unify file and auto for transfering Signed-off-by: Miek Gieben <miek@miek.nl> * fix test Signed-off-by: Miek Gieben <miek@miek.nl> * properly merge Signed-off-by: Miek Gieben <miek@miek.nl> * Remove plugin/kubernetes/setup_transfer_test.go Signed-off-by: Yong Tang <yong.tang.github@outlook.com> Co-authored-by: Miek Gieben <miek@miek.nl>
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # file
 | |
| 
 | |
| ## Name
 | |
| 
 | |
| *file* - enables serving zone data from an RFC 1035-style master file.
 | |
| 
 | |
| ## Description
 | |
| 
 | |
| The *file* plugin is used for an "old-style" DNS server. It serves from a preloaded file that exists
 | |
| on disk. 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.
 | |
| 
 | |
| ## Syntax
 | |
| 
 | |
| ~~~
 | |
| file DBFILE [ZONES...]
 | |
| ~~~
 | |
| 
 | |
| * **DBFILE** the database file to read and parse. If the path is relative, the path from the *root*
 | |
|   plugin will be prepended to it.
 | |
| * **ZONES** zones it should be authoritative for. If empty, the zones from the configuration block
 | |
|   are used.
 | |
| 
 | |
| If you want to round-robin A and AAAA responses look at the *loadbalance* plugin.
 | |
| 
 | |
| ~~~
 | |
| file DBFILE [ZONES... ] {
 | |
|     reload DURATION
 | |
| }
 | |
| ~~~
 | |
| 
 | |
| * `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.
 | |
| 
 | |
| If you need outgoing zone transfers, take a look at the *transfer* plugin.
 | |
| 
 | |
| ## Examples
 | |
| 
 | |
| Load the `example.org` zone from `example.org.signed` and allow transfers to the internet, but send
 | |
| notifies to 10.240.1.1
 | |
| 
 | |
| ~~~ corefile
 | |
| example.org {
 | |
|     file example.org.signed
 | |
|     transfer {
 | |
|         to * 10.240.1.1
 | |
|     }
 | |
| }
 | |
| ~~~
 | |
| 
 | |
| Or use a single zone file for multiple zones:
 | |
| 
 | |
| ~~~ corefile
 | |
| . {
 | |
|     file example.org.signed example.org example.net
 | |
|     transfer example.org example.net {
 | |
|         to * 10.240.1.1
 | |
|     }
 | |
| }
 | |
| ~~~
 | |
| 
 | |
| Note that if you have a configuration like the following you may run into a problem of the origin
 | |
| not being correctly recognized:
 | |
| 
 | |
| ~~~ corefile
 | |
| . {
 | |
|     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.
 | |
| It's better to be explicit here and specify the correct origin. This can be done in two ways:
 | |
| 
 | |
| ~~~ corefile
 | |
| . {
 | |
|     file db.example.org example.org
 | |
| }
 | |
| ~~~
 | |
| 
 | |
| Or
 | |
| 
 | |
| ~~~ corefile
 | |
| example.org {
 | |
|     file db.example.org
 | |
| }
 | |
| ~~~
 | |
| 
 | |
| ## Also See
 | |
| 
 | |
| See the *loadbalance* plugin if you need simple record shuffling. And the *transfer* plugin for zone
 | |
| transfers. Lastly the *root* plugin can help you specificy the location of the zone files.
 |