Commit 599cd283 authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 9d963b88
...@@ -58,7 +58,7 @@ type Client struct { ...@@ -58,7 +58,7 @@ type Client struct {
// driver client <- watcher: database commits | errors. // driver client <- watcher: database commits | errors.
watchq chan<- zodb.Event watchq chan<- zodb.Event
head zodb.Tid // last invalidation received from server head zodb.Tid // last invalidation received from server
head0 zodb.Tid // .head state on start of every talkMaster1 head0 zodb.Tid // .head state on start of every (re)connection to master
at0Mu sync.Mutex at0Mu sync.Mutex
at0 zodb.Tid // at0 obtained when initially connecting to server at0 zodb.Tid // at0 obtained when initially connecting to server
......
...@@ -24,7 +24,7 @@ import ( ...@@ -24,7 +24,7 @@ import (
"context" "context"
"fmt" "fmt"
"sync" "sync"
"time" // "time"
"github.com/pkg/errors" "github.com/pkg/errors"
...@@ -48,7 +48,7 @@ import ( ...@@ -48,7 +48,7 @@ import (
// //
// Storage implements only NEO protocol logic with data being persisted via provided storage.Backend. // Storage implements only NEO protocol logic with data being persisted via provided storage.Backend.
type Storage struct { type Storage struct {
node *xneo.Node node *_MasteredNode
// context for providing operational service // context for providing operational service
// it is renewed every time master tells us StartOpertion, so users // it is renewed every time master tells us StartOpertion, so users
...@@ -57,8 +57,6 @@ type Storage struct { ...@@ -57,8 +57,6 @@ type Storage struct {
opCtx context.Context opCtx context.Context
back storage.Backend back storage.Backend
//nodeCome chan nodeCome // node connected
} }
// NewStorage creates new storage node that will talk to master on masterAddr. // NewStorage creates new storage node that will talk to master on masterAddr.
...@@ -67,7 +65,7 @@ type Storage struct { ...@@ -67,7 +65,7 @@ type Storage struct {
// Use Run to actually start running the node. // Use Run to actually start running the node.
func NewStorage(clusterName, masterAddr string, net xnet.Networker, back storage.Backend) *Storage { func NewStorage(clusterName, masterAddr string, net xnet.Networker, back storage.Backend) *Storage {
stor := &Storage{ stor := &Storage{
node: xneo.NewNode(net, proto.STORAGE, clusterName, masterAddr), node: newMasteredNode(proto.STORAGE, clusterName, net, masterAddr),
back: back, back: back,
} }
...@@ -93,15 +91,16 @@ func (stor *Storage) Run(ctx context.Context, l xnet.Listener) (err error) { ...@@ -93,15 +91,16 @@ func (stor *Storage) Run(ctx context.Context, l xnet.Listener) (err error) {
if err != nil { if err != nil {
return err return err
} }
stor.node.MyInfo.Addr = naddr stor.node.myInfo.Addr = naddr
// wrap listener with link / identificaton hello checker // wrap listener with link / identificaton hello checker
lli := xneo.NewListener(neonet.NewLinkListener(l)) lli := xneo.NewListener(neonet.NewLinkListener(l))
// start serving incoming connections // start serving incoming connections
wg := sync.WaitGroup{} wg := sync.WaitGroup{}
serveCtx, serveCancel := context.WithCancel(ctx)
/*
serveCtx, serveCancel := context.WithCancel(ctx)
//stor.node.OnShutdown = serveCancel //stor.node.OnShutdown = serveCancel
// XXX hack: until ctx cancel is not handled properly by Recv/Send // XXX hack: until ctx cancel is not handled properly by Recv/Send
// XXX -> xcontext.WithCloseOnRetCancel // XXX -> xcontext.WithCloseOnRetCancel
...@@ -109,13 +108,16 @@ func (stor *Storage) Run(ctx context.Context, l xnet.Listener) (err error) { ...@@ -109,13 +108,16 @@ func (stor *Storage) Run(ctx context.Context, l xnet.Listener) (err error) {
serveCancel() serveCancel()
xio.LClose(ctx, lli) xio.LClose(ctx, lli)
} }
*/
wg.Add(1) wg.Add(1)
go func(ctx context.Context) (err error) { go func(ctx context.Context) (err error) {
defer wg.Done() defer wg.Done()
defer task.Running(&ctx, "accept")(&err) defer task.Running(&ctx, "accept")(&err)
// XXX dup from master // XXX dup from master -> Node.Listen() -> Accept() ?
// XXX ? -> Node.Accept(lli) (it will verify IdTime against Node.nodeTab[nid])
// XXX ? -> Node.Serve(lli -> func(idReq))
for { for {
if ctx.Err() != nil { if ctx.Err() != nil {
return ctx.Err() return ctx.Err()
...@@ -147,28 +149,39 @@ func (stor *Storage) Run(ctx context.Context, l xnet.Listener) (err error) { ...@@ -147,28 +149,39 @@ func (stor *Storage) Run(ctx context.Context, l xnet.Listener) (err error) {
// continue // continue
// } // }
} }
}(serveCtx) // }(serveCtx)
}(ctx)
// connect to master and get commands and updates from it // connect to master and get commands and updates from it
//err = stor.talkMaster(ctx) err = stor.talkMaster(ctx)
err = stor.talkMaster(serveCtx) // XXX hack for shutdown // err = stor.talkMaster(serveCtx) // XXX hack for shutdown
// XXX log err? // XXX log err?
// we are done - shutdown // we are done - shutdown
serveCancel() // serveCancel()
wg.Wait() wg.Wait()
// XXX should Storage do it, or should it leave back non-closed? // XXX should Storage do it, or should it leave back non-closed?
// TODO -> Storage should not close backend.
err2 := stor.back.Close() err2 := stor.back.Close()
if err == nil { if err == nil {
err = err2 err = err2
} }
return err // XXX err ctx return err
} }
// --- connect to master and let it drive us --- // --- connect to master and let it drive us ---
// XXX move -> SetNumReplicas handler
/*
// NumReplicas: neo/py meaning for n(replica) = `n(real-replica) - 1`
if !(accept.NumPartitions == 1 && accept.NumReplicas == 0) {
return fmt.Errorf("TODO for 1-storage POC: Npt: %v Nreplica: %v", accept.NumPartitions, accept.NumReplicas)
}
*/
/* XXX kill
// talkMaster connects to master, announces self and receives commands and notifications. // talkMaster connects to master, announces self and receives commands and notifications.
// it tries to persist master link reconnecting as needed. // it tries to persist master link reconnecting as needed.
// //
...@@ -220,13 +233,6 @@ func (stor *Storage) talkMaster1(ctx context.Context) (err error) { ...@@ -220,13 +233,6 @@ func (stor *Storage) talkMaster1(ctx context.Context) (err error) {
// XXX add master NID -> nodeTab ? or master will notify us with it himself ? // XXX add master NID -> nodeTab ? or master will notify us with it himself ?
// XXX move -> SetNumReplicas handler
/*
// NumReplicas: neo/py meaning for n(replica) = `n(real-replica) - 1`
if !(accept.NumPartitions == 1 && accept.NumReplicas == 0) {
return fmt.Errorf("TODO for 1-storage POC: Npt: %v Nreplica: %v", accept.NumPartitions, accept.NumReplicas)
}
*/
// XXX -> node.Dial ? // XXX -> node.Dial ?
if accept.YourNID != stor.node.MyInfo.NID { if accept.YourNID != stor.node.MyInfo.NID {
...@@ -251,6 +257,7 @@ func (stor *Storage) talkMaster1(ctx context.Context) (err error) { ...@@ -251,6 +257,7 @@ func (stor *Storage) talkMaster1(ctx context.Context) (err error) {
//log.Error(ctx, err) //log.Error(ctx, err)
return err return err
} }
*/
// m1initialize drives storage by master messages during initialization phase // m1initialize drives storage by master messages during initialization phase
// //
...@@ -267,7 +274,7 @@ func (stor *Storage) m1initialize(ctx context.Context, mlink *neonet.NodeLink) ( ...@@ -267,7 +274,7 @@ func (stor *Storage) m1initialize(ctx context.Context, mlink *neonet.NodeLink) (
defer task.Runningf(&ctx, "init %v", mlink)(&err) defer task.Runningf(&ctx, "init %v", mlink)(&err)
for { for {
req, err := mlink.Recv1() req, err := mlink.Recv1() // XXX -> RecvM1
if err != nil { if err != nil {
return nil, err return nil, err
} }
...@@ -377,7 +384,7 @@ func (stor *Storage) m1serve(ctx context.Context, reqStart *neonet.Request) (err ...@@ -377,7 +384,7 @@ func (stor *Storage) m1serve(ctx context.Context, reqStart *neonet.Request) (err
for { for {
// XXX abort on ctx (XXX or upper?) // XXX abort on ctx (XXX or upper?)
req, err := mlink.Recv1() req, err := mlink.Recv1() // XXX -> RecvM1
if err != nil { if err != nil {
return err return err
} }
......
...@@ -66,7 +66,6 @@ import ( ...@@ -66,7 +66,6 @@ import (
// XXX users have to care locking explicitly // XXX users have to care locking explicitly
type NodeTable struct { type NodeTable struct {
// XXX for PeerNode.Dial to work. see also comments vvv near "peer link" // XXX for PeerNode.Dial to work. see also comments vvv near "peer link"
// XXX move pointer to local node to PeerNode instead?
localNode *Node localNode *Node
nodev []*PeerNode // all nodes nodev []*PeerNode // all nodes
...@@ -77,13 +76,13 @@ type NodeTable struct { ...@@ -77,13 +76,13 @@ type NodeTable struct {
// PeerNode represents a peer node in the cluster. // PeerNode represents a peer node in the cluster.
type PeerNode struct { type PeerNode struct {
nodeTab *NodeTable // this node is part of // XXX -> change to `local *Node` ? nodeTab *NodeTable // this node is part of
proto.NodeInfo // (.type, .laddr, .nid, .state, .idtime) XXX also protect by mu? proto.NodeInfo // (.type, .laddr, .nid, .state, .idtime) XXX also protect by mu?
linkMu sync.Mutex linkMu sync.Mutex
link *neonet.NodeLink // link to this peer; nil if not connected link *neonet.NodeLink // link to this peer; nil if not connected
dialT time.Time // last dial finished at this time dialT time.Time // last dial finished at this time
// dialer notifies waiters via this; reinitialized at each redial; nil while not dialing // dialer notifies waiters via this; reinitialized at each redial; nil while not dialing
// //
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment