Don't publish the process rpc call and embed the router handler in the network
This commit is contained in:
parent
b1c49a0ddc
commit
7884e889f4
@ -1,19 +1,40 @@
|
|||||||
package network
|
package network
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"github.com/micro/go-micro/client"
|
"github.com/micro/go-micro/client"
|
||||||
"github.com/micro/go-micro/network/proxy/mucp"
|
"github.com/micro/go-micro/network/proxy/mucp"
|
||||||
"github.com/micro/go-micro/network/router"
|
"github.com/micro/go-micro/network/router"
|
||||||
|
"github.com/micro/go-micro/network/router/handler"
|
||||||
|
pb "github.com/micro/go-micro/network/router/proto"
|
||||||
"github.com/micro/go-micro/server"
|
"github.com/micro/go-micro/server"
|
||||||
)
|
)
|
||||||
|
|
||||||
type network struct {
|
type network struct {
|
||||||
name string
|
|
||||||
options Options
|
options Options
|
||||||
|
handler server.Router
|
||||||
|
router pb.RouterService
|
||||||
|
|
||||||
|
sync.RWMutex
|
||||||
|
connected bool
|
||||||
|
exit chan bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (n *network) Name() string {
|
func (n *network) Name() string {
|
||||||
return n.name
|
return n.options.Name
|
||||||
|
}
|
||||||
|
|
||||||
|
// Implements the server.ServeRequest method.
|
||||||
|
func (n *network) ServeRequest(ctx context.Context, req server.Request, rsp server.Response) error {
|
||||||
|
// If we're being called then execute our handlers
|
||||||
|
if req.Service() == n.options.Name {
|
||||||
|
return n.handler.ServeRequest(ctx, req, rsp)
|
||||||
|
}
|
||||||
|
|
||||||
|
// execute the proxy
|
||||||
|
return n.options.Proxy.ServeRequest(ctx, req, rsp)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (n *network) Connect() error {
|
func (n *network) Connect() error {
|
||||||
@ -21,9 +42,60 @@ func (n *network) Connect() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (n *network) Close() error {
|
func (n *network) Close() error {
|
||||||
|
n.Lock()
|
||||||
|
defer n.Unlock()
|
||||||
|
|
||||||
|
// check if we're connected
|
||||||
|
if !n.connected {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
advertChan, err := n.options.Router.Advertise()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
go n.run(advertChan)
|
||||||
|
|
||||||
|
// stop the server
|
||||||
return n.options.Server.Stop()
|
return n.options.Server.Stop()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (n *network) run(advertChan <-chan *router.Advert) {
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
// process local adverts and randomly fire them at other nodes
|
||||||
|
case a := <-advertChan:
|
||||||
|
// create a proto advert
|
||||||
|
var events []*pb.Event
|
||||||
|
for _, event := range a.Events {
|
||||||
|
route := &pb.Route{
|
||||||
|
Service: event.Route.Service,
|
||||||
|
Address: event.Route.Address,
|
||||||
|
Gateway: event.Route.Gateway,
|
||||||
|
Network: event.Route.Network,
|
||||||
|
Link: event.Route.Link,
|
||||||
|
Metric: int64(event.Route.Metric),
|
||||||
|
}
|
||||||
|
e := &pb.Event{
|
||||||
|
Type: pb.EventType(event.Type),
|
||||||
|
Timestamp: event.Timestamp.UnixNano(),
|
||||||
|
Route: route,
|
||||||
|
}
|
||||||
|
events = append(events, e)
|
||||||
|
}
|
||||||
|
|
||||||
|
// fire the advert to a random network node
|
||||||
|
n.router.Process(context.Background(), &pb.Advert{
|
||||||
|
Id: n.options.Router.Options().Id,
|
||||||
|
Type: pb.AdvertType(a.Type),
|
||||||
|
Timestamp: a.Timestamp.UnixNano(),
|
||||||
|
Events: events,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// newNetwork returns a new network node
|
// newNetwork returns a new network node
|
||||||
func newNetwork(opts ...Option) Network {
|
func newNetwork(opts ...Option) Network {
|
||||||
options := Options{
|
options := Options{
|
||||||
@ -39,15 +111,24 @@ func newNetwork(opts ...Option) Network {
|
|||||||
o(&options)
|
o(&options)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// get the default server handler
|
||||||
|
sr := server.DefaultRouter
|
||||||
|
// create new router handler
|
||||||
|
hd := sr.NewHandler(&handler.Router{options.Router})
|
||||||
|
// register the router handler
|
||||||
|
sr.Handle(hd)
|
||||||
|
|
||||||
// set the server name
|
// set the server name
|
||||||
options.Server.Init(
|
options.Server.Init(
|
||||||
server.Name(options.Name),
|
server.Name(options.Name),
|
||||||
server.Address(options.Address),
|
server.Address(options.Address),
|
||||||
server.Advertise(options.Advertise),
|
server.Advertise(options.Advertise),
|
||||||
server.WithRouter(options.Proxy),
|
server.WithRouter(sr),
|
||||||
)
|
)
|
||||||
|
|
||||||
return &network{
|
return &network{
|
||||||
options: options,
|
options: options,
|
||||||
|
handler: sr,
|
||||||
|
router: pb.NewRouterService(options.Name, options.Client),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -142,6 +142,11 @@ func NewServer(opt ...Option) Server {
|
|||||||
return newRpcServer(opt...)
|
return newRpcServer(opt...)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewRouter returns a new router
|
||||||
|
func NewRouter() *router {
|
||||||
|
return newRpcRouter()
|
||||||
|
}
|
||||||
|
|
||||||
// NewSubscriber creates a new subscriber interface with the given topic
|
// NewSubscriber creates a new subscriber interface with the given topic
|
||||||
// and handler using the default server
|
// and handler using the default server
|
||||||
func NewSubscriber(topic string, h interface{}, opts ...SubscriberOption) Subscriber {
|
func NewSubscriber(topic string, h interface{}, opts ...SubscriberOption) Subscriber {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user