core

package
v0.0.0-...-ad2838b Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 13, 2016 License: Apache-2.0 Imports: 25 Imported by: 0

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:

  1. Set the AppName and AppVersion variables.
  2. 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.
  3. 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

View Source
const (
	// DefaultHost is the default host.
	DefaultHost = ""
	// DefaultPort is the default port.
	DefaultPort = "53"
	// DefaultRoot is the default root folder.
	DefaultRoot = "."
)
View Source
const (
	// DefaultConfigFile is the name of the configuration file that is loaded
	// by default if no other file is specified.
	DefaultConfigFile = "Corefile"
)

Variables

View Source
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

View Source
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

func RegisterDirective(name string, setup SetupFunc, after string)

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

func Restart(newCorefile Input) error

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

func Start(crfile Input) (err error)

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

func TestServer(t *testing.T, corefile string) (*server.Server, error)

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.

func Wait

func Wait()

Wait blocks until all servers are stopped.

Types

type CorefileInput

type CorefileInput struct {
	Filepath string
	Contents []byte
	RealFile bool
}

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) Body

func (c CorefileInput) Body() []byte

Body returns c.Contents.

func (CorefileInput) IsFile

func (c CorefileInput) IsFile() bool

IsFile returns true if the original input was a real file on the file system.

func (CorefileInput) Path

func (c CorefileInput) Path() string

Path returns c.Filepath.

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 Corefile

func Corefile() Input

Corefile returns the current Corefile

func CorefileFromPipe

func CorefileFromPipe(f *os.File) (Input, error)

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

func LoadCorefile(loader func() (Input, error)) (crfile Input, err error)

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.

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL