2019-08-05 20:04:47 +03:00
|
|
|
// Package network is for creating internetworks
|
|
|
|
package network
|
2019-08-20 14:48:51 +03:00
|
|
|
|
|
|
|
import (
|
2019-08-20 23:12:21 +03:00
|
|
|
"time"
|
|
|
|
|
2019-08-20 14:48:51 +03:00
|
|
|
"github.com/micro/go-micro/client"
|
|
|
|
"github.com/micro/go-micro/server"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// DefaultName is default network name
|
2019-08-21 21:21:23 +03:00
|
|
|
DefaultName = "go.micro"
|
2019-08-20 14:48:51 +03:00
|
|
|
// DefaultAddress is default network address
|
|
|
|
DefaultAddress = ":0"
|
2019-08-28 22:11:19 +03:00
|
|
|
// ResolveTime defines time interval to periodically resolve network nodes
|
2019-08-20 23:12:21 +03:00
|
|
|
ResolveTime = 1 * time.Minute
|
2019-08-28 22:11:19 +03:00
|
|
|
// AnnounceTime defines time interval to periodically announce node neighbours
|
|
|
|
AnnounceTime = 30 * time.Second
|
2019-09-03 12:00:14 +03: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 14:48:51 +03:00
|
|
|
)
|
|
|
|
|
2019-09-02 19:06:21 +03:00
|
|
|
// Node is network node
|
|
|
|
type Node interface {
|
|
|
|
// Id is node id
|
|
|
|
Id() string
|
|
|
|
// Address is node bind address
|
|
|
|
Address() string
|
2019-09-10 03:14:23 +03:00
|
|
|
// Peers returns node peers
|
|
|
|
Peers() []Node
|
2019-09-02 19:06:21 +03:00
|
|
|
// Network is the network node is in
|
|
|
|
Network() Network
|
|
|
|
}
|
|
|
|
|
2019-08-20 14:48:51 +03:00
|
|
|
// Network is micro network
|
|
|
|
type Network interface {
|
2019-09-02 14:39:26 +03:00
|
|
|
// Node is network node
|
|
|
|
Node
|
2019-09-02 13:42:45 +03:00
|
|
|
// Options returns the network options
|
|
|
|
Options() Options
|
2019-08-20 14:48:51 +03: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...)
|
|
|
|
}
|