package discovery

import "github.com/coreos/etcd/discovery"

Package discovery provides an implementation of the cluster discovery that is used by etcd.

Index

Variables

var (
	ErrInvalidURL           = errors.New("discovery: invalid URL")
	ErrBadSizeKey           = errors.New("discovery: size key is bad")
	ErrSizeNotFound         = errors.New("discovery: size key not found")
	ErrTokenNotFound        = errors.New("discovery: token not found")
	ErrDuplicateID          = errors.New("discovery: found duplicate id")
	ErrDuplicateName        = errors.New("discovery: found duplicate name")
	ErrFullCluster          = errors.New("discovery: cluster is full")
	ErrTooManyRetries       = errors.New("discovery: too many retries")
	ErrBadDiscoveryEndpoint = errors.New("discovery: bad discovery endpoint")
)

Functions

func GetCluster

func GetCluster(durl, dproxyurl string) (string, error)

GetCluster will connect to the discovery service at the given url and retrieve a string describing the cluster

func JoinCluster

func JoinCluster(durl, dproxyurl string, id types.ID, config string) (string, error)

JoinCluster will connect to the discovery service at the given url, and register the server represented by the given id and config to the cluster

func SRVGetCluster

func SRVGetCluster(name, dns string, defaultToken string, apurls types.URLs) (string, string, error)

SRVGetCluster gets the cluster information via DNS discovery. TODO(barakmich): Currently ignores priority and weight (as they don't make as much sense for a bootstrap) Also doesn't do any lookups for the token (though it could) Also sees each entry as a separate instance.

Source Files

discovery.go srv.go

Version
v2.3.8+incompatible (latest)
Published
Feb 16, 2017
Platform
linux/amd64
Imports
16 packages
Last checked
19 hours ago

Tools for package owners.