Documentation ¶
Index ¶
- Constants
- type CaseInsensitive
- type CaseSensitive
- type DNSServer
- type Entries
- type Entry
- type EntryStatus
- type GossipData
- type Nameserver
- func (n *Nameserver) AddEntry(hostname, containerid string, origin mesh.PeerName, addr address.Address)
- func (n *Nameserver) AddEntryFQDN(fqdn, containerid string, origin mesh.PeerName, addr address.Address)
- func (n *Nameserver) ContainerDestroyed(ident string)
- func (n *Nameserver) ContainerDied(ident string)
- func (n *Nameserver) ContainerStarted(ident string)
- func (n *Nameserver) Delete(hostname, containerid, ipStr string, ip address.Address)
- func (n *Nameserver) Gossip() mesh.GossipData
- func (n *Nameserver) HandleHTTP(router *mux.Router, dockerCli *docker.Client)
- func (n *Nameserver) Lookup(hostname string) []address.Address
- func (n *Nameserver) OnGossip(msg []byte) (mesh.GossipData, error)
- func (n *Nameserver) OnGossipBroadcast(_ mesh.PeerName, msg []byte) (mesh.GossipData, error)
- func (n *Nameserver) OnGossipUnicast(sender mesh.PeerName, msg []byte) error
- func (n *Nameserver) PeerGone(peer mesh.PeerName)
- func (n *Nameserver) ReverseLookup(ip address.Address) (string, error)
- func (n *Nameserver) SetGossip(gossip mesh.Gossip)
- func (n *Nameserver) Start()
- func (n *Nameserver) Stop()
- type SortableEntries
- type Status
- type Upstream
Constants ¶
View Source
const ( DefaultListenAddress = "0.0.0.0:53" DefaultTTL = 1 DefaultClientTimeout = 5 * time.Second )
View Source
const (
// Used by prog/weaver/main.go and proxy/create_container_interceptor.go
DefaultDomain = "weave.local."
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CaseInsensitive ¶
type CaseInsensitive Entries
func (CaseInsensitive) Get ¶
func (es CaseInsensitive) Get(i int) Entry
func (CaseInsensitive) Len ¶
func (es CaseInsensitive) Len() int
... but we store entries in a case insensitive order.
func (CaseInsensitive) Less ¶
func (es CaseInsensitive) Less(i, j int) bool
func (CaseInsensitive) Swap ¶
func (es CaseInsensitive) Swap(i, j int)
type CaseSensitive ¶
type CaseSensitive Entries
func (CaseSensitive) Get ¶
func (es CaseSensitive) Get(i int) Entry
func (CaseSensitive) Len ¶
func (es CaseSensitive) Len() int
Gossip messages are sorted in a case sensitive order...
func (CaseSensitive) Less ¶
func (es CaseSensitive) Less(i, j int) bool
func (CaseSensitive) Swap ¶
func (es CaseSensitive) Swap(i, j int)
type DNSServer ¶
type DNSServer struct {
// contains filtered or unexported fields
}
func NewDNSServer ¶
func (*DNSServer) ActivateAndServe ¶
func (d *DNSServer) ActivateAndServe()
type Entry ¶
type EntryStatus ¶
type GossipData ¶
func (*GossipData) Decode ¶
func (g *GossipData) Decode(msg []byte) error
func (*GossipData) Encode ¶
func (g *GossipData) Encode() [][]byte
func (*GossipData) Merge ¶
func (g *GossipData) Merge(o mesh.GossipData) mesh.GossipData
type Nameserver ¶
Nameserver: gossip-based, in memory nameserver. - Holds a sorted list of (hostname, peer, container id, ip) tuples for the whole cluster. - This list is gossiped & merged around the cluser. - Lookup-by-hostname are O(nlogn), and return a (copy of a) slice of the entries - Update is O(n) for now
func (*Nameserver) AddEntryFQDN ¶
func (*Nameserver) ContainerDestroyed ¶
func (n *Nameserver) ContainerDestroyed(ident string)
func (*Nameserver) ContainerDied ¶
func (n *Nameserver) ContainerDied(ident string)
func (*Nameserver) ContainerStarted ¶
func (n *Nameserver) ContainerStarted(ident string)
func (*Nameserver) Delete ¶
func (n *Nameserver) Delete(hostname, containerid, ipStr string, ip address.Address)
func (*Nameserver) Gossip ¶
func (n *Nameserver) Gossip() mesh.GossipData
func (*Nameserver) HandleHTTP ¶
func (n *Nameserver) HandleHTTP(router *mux.Router, dockerCli *docker.Client)
func (*Nameserver) OnGossip ¶
func (n *Nameserver) OnGossip(msg []byte) (mesh.GossipData, error)
merge received data into state and return "everything new I've just learnt", or nil if nothing in the received data was new
func (*Nameserver) OnGossipBroadcast ¶
func (n *Nameserver) OnGossipBroadcast(_ mesh.PeerName, msg []byte) (mesh.GossipData, error)
merge received data into state and return a representation of the received data, for further propagation
func (*Nameserver) OnGossipUnicast ¶
func (n *Nameserver) OnGossipUnicast(sender mesh.PeerName, msg []byte) error
func (*Nameserver) PeerGone ¶
func (n *Nameserver) PeerGone(peer mesh.PeerName)
func (*Nameserver) ReverseLookup ¶
func (n *Nameserver) ReverseLookup(ip address.Address) (string, error)
func (*Nameserver) SetGossip ¶
func (n *Nameserver) SetGossip(gossip mesh.Gossip)
func (*Nameserver) Start ¶
func (n *Nameserver) Start()
func (*Nameserver) Stop ¶
func (n *Nameserver) Stop()
type Status ¶
type Status struct { Domain string Upstream []string Address string TTL uint32 Entries []EntryStatus }
func NewStatus ¶
func NewStatus(ns *Nameserver, dnsServer *DNSServer) *Status
Click to show internal directories.
Click to hide internal directories.