Documentation ¶
Overview ¶
Package core implements the CoreDNS web server as a service in your own Go programs.
To use this package, follow a few simple steps:
- Set the AppName and AppVersion variables.
- Call LoadCorefile() to get the Corefile (it might have been piped in as part of a restart). You should pass in your own Corefile loader.
- Call core.Start() to start CoreDNS, core.Stop() to stop it, or core.Restart() to restart it.
You should use core.Wait() to wait for all CoreDNS servers to quit before your process exits.
Index ¶
- Constants
- Variables
- func IsRestart() bool
- func RegisterDirective(name string, setup SetupFunc, after string)
- func Restart(newCorefile Input) error
- func Start(crfile Input) (err error)
- func Stop() error
- func TestServer(t *testing.T, corefile string) (*server.Server, error)
- func TrapSignals()
- func Wait()
- type CorefileInput
- type Input
- type SetupFunc
Constants ¶
const ( // DefaultHost is the default host. DefaultHost = "" // DefaultPort is the default port. DefaultPort = "53" // DefaultRoot is the default root folder. DefaultRoot = "." )
const ( // DefaultConfigFile is the name of the configuration file that is loaded // by default if no other file is specified. DefaultConfigFile = "Corefile" )
Variables ¶
var ( // Root is the site root Root = DefaultRoot // Host is the site host Host = DefaultHost // Port is the site port Port = DefaultPort )
These defaults are configurable through the command line
var ( // AppName is the name of the application. AppName string // AppVersion is the version of the application. AppVersion string // Quiet when set to true, will not show any informative output on initialization. Quiet bool // PidFile is the path to the pidfile to create. PidFile string // GracefulTimeout is the maximum duration of a graceful shutdown. GracefulTimeout time.Duration )
Configurable application parameters
Functions ¶
func IsRestart ¶
func IsRestart() bool
IsRestart returns whether this process is, according to env variables, a fork as part of a graceful restart.
func RegisterDirective ¶
RegisterDirective adds the given directive to CoreDNS's list of directives. Pass the name of a directive you want it to be placed after, otherwise it will be placed at the bottom of the stack.
func Restart ¶
Restart restarts the entire application; gracefully with zero downtime if on a POSIX-compatible system, or forcefully if on Windows but with imperceptibly-short downtime.
The restarted application will use newCorefile as its input configuration. If newCorefile is nil, the current (existing) Corefile configuration will be used.
Note: The process must exist in the same place on the disk in order for this to work. Thus, multiple graceful restarts don't work if executing with `go run`, since the binary is cleaned up when `go run` sees the initial parent process exit.
func Start ¶
Start starts CoreDNS with the given Corefile. If crfile is nil, the LoadCorefile function will be called to get one.
This function blocks until all the servers are listening.
Note (POSIX): If Start is called in the child process of a restart more than once within the duration of the graceful cutoff (i.e. the child process called Start a first time, then called Stop, then Start again within the first 5 seconds or however long GracefulTimeout is) and the Corefiles have at least one listener address in common, the second Start may fail with "address already in use" as there's no guarantee that the parent process has relinquished the address before the grace period ends.
func Stop ¶
func Stop() error
Stop stops all servers. It blocks until they are all stopped. It does NOT execute shutdown callbacks that may have been configured by middleware (they must be executed separately).
func TestServer ¶
TestServer returns a test server. The ports can be retreived with server.LocalAddr(). The testserver itself can be stopped with Stop(). It just takes a normal Corefile as input.
func TrapSignals ¶
func TrapSignals()
TrapSignals create signal handlers for all applicable signals for this system. If your Go program uses signals, this is a rather invasive function; best to implement them yourself in that case. Signals are not required for the caddy package to function properly, but this is a convenient way to allow the user to control this package of your program.
Types ¶
type CorefileInput ¶
CorefileInput represents a Corefile as input and is simply a convenient way to implement the Input interface.
func DefaultInput ¶
func DefaultInput() CorefileInput
DefaultInput returns the default Corefile input to use when it is otherwise empty or missing. It uses the default host and port and root.
func (CorefileInput) IsFile ¶
func (c CorefileInput) IsFile() bool
IsFile returns true if the original input was a real file on the file system.
type Input ¶
type Input interface { // Gets the Corefile contents Body() []byte // Gets the path to the origin file Path() string // IsFile returns true if the original input was a file on the file system // that could be loaded again later if requested. IsFile() bool }
Input represents a Corefile; its contents and file path (which should include the file name at the end of the path). If path does not apply (e.g. piped input) you may use any understandable value. The path is mainly used for logging, error messages, and debugging.
func CorefileFromPipe ¶
CorefileFromPipe loads the Corefile input from f if f is not interactive input. f is assumed to be a pipe or stream, such as os.Stdin. If f is not a pipe, no error is returned but the Input value will be nil. An error is only returned if there was an error reading the pipe, even if the length of what was read is 0.
func LoadCorefile ¶
LoadCorefile loads a Corefile, prioritizing a Corefile piped from stdin as part of a restart (only happens on first call to LoadCorefile). If it is not a restart, this function tries calling the user's loader function, and if that returns nil, then this function resorts to the default configuration. Thus, if there are no other errors, this function always returns at least the default Corefile.
type SetupFunc ¶
type SetupFunc func(c *setup.Controller) (middleware.Middleware, error)
SetupFunc takes a controller and may optionally return a middleware. If the resulting middleware is not nil, it will be chained into the DNS handlers in the order specified in this package.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package https facilitates the management of TLS assets and integrates Let's Encrypt functionality into CoreDNS with first-class support for creating and renewing certificates automatically.
|
Package https facilitates the management of TLS assets and integrates Let's Encrypt functionality into CoreDNS with first-class support for creating and renewing certificates automatically. |
Package parse provides facilities for parsing configuration files.
|
Package parse provides facilities for parsing configuration files. |