2019-08-05 18:04:47 +01:00
|
|
|
// Package network is for creating internetworks
|
|
|
|
package network
|
2019-08-20 12:48:51 +01:00
|
|
|
|
|
|
|
import (
|
2019-08-20 21:12:21 +01:00
|
|
|
"time"
|
|
|
|
|
2019-08-20 12:48:51 +01:00
|
|
|
"github.com/micro/go-micro/client"
|
|
|
|
"github.com/micro/go-micro/server"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// DefaultName is default network name
|
2019-08-21 19:21:23 +01:00
|
|
|
DefaultName = "go.micro"
|
2019-08-20 12:48:51 +01:00
|
|
|
// DefaultAddress is default network address
|
|
|
|
DefaultAddress = ":0"
|
2019-08-28 20:11:19 +01:00
|
|
|
// ResolveTime defines time interval to periodically resolve network nodes
|
2019-08-20 21:12:21 +01:00
|
|
|
ResolveTime = 1 * time.Minute
|
2019-08-28 20:11:19 +01:00
|
|
|
// AnnounceTime defines time interval to periodically announce node neighbours
|
|
|
|
AnnounceTime = 30 * time.Second
|
2019-09-03 10:00:14 +01:00
|
|
|
// PruneTime defines time interval to periodically check nodes that need to be pruned
|
|
|
|
// due to their not announcing their presence within this time interval
|
|
|
|
PruneTime = 90 * time.Second
|
2019-08-20 12:48:51 +01:00
|
|
|
)
|
|
|
|
|
2019-09-02 17:06:21 +01:00
|
|
|
// Node is network node
|
|
|
|
type Node interface {
|
|
|
|
// Id is node id
|
|
|
|
Id() string
|
|
|
|
// Address is node bind address
|
|
|
|
Address() string
|
2019-09-10 01:14:23 +01:00
|
|
|
// Peers returns node peers
|
|
|
|
Peers() []Node
|
2019-09-02 17:06:21 +01:00
|
|
|
// Network is the network node is in
|
|
|
|
Network() Network
|
|
|
|
}
|
|
|
|
|
2019-08-20 12:48:51 +01:00
|
|
|
// Network is micro network
|
|
|
|
type Network interface {
|
2019-09-02 12:39:26 +01:00
|
|
|
// Node is network node
|
|
|
|
Node
|
2019-10-13 12:38:13 +01:00
|
|
|
// Initialise options
|
|
|
|
Init(...Option) error
|
2019-09-02 11:42:45 +01:00
|
|
|
// Options returns the network options
|
|
|
|
Options() Options
|
2019-08-20 12:48:51 +01:00
|
|
|
// Name of the network
|
|
|
|
Name() string
|
|
|
|
// Connect starts the resolver and tunnel server
|
|
|
|
Connect() error
|
|
|
|
// Close stops the tunnel and resolving
|
|
|
|
Close() error
|
|
|
|
// Client is micro client
|
|
|
|
Client() client.Client
|
|
|
|
// Server is micro server
|
|
|
|
Server() server.Server
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewNetwork returns a new network interface
|
|
|
|
func NewNetwork(opts ...Option) Network {
|
|
|
|
return newNetwork(opts...)
|
|
|
|
}
|