Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neo
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
2
Merge Requests
2
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
Kirill Smelkov
neo
Commits
35b5e962
Commit
35b5e962
authored
Aug 15, 2017
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
df5aca5b
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
59 additions
and
11 deletions
+59
-11
go/neo/connection.go
go/neo/connection.go
+53
-10
go/neo/proto.go
go/neo/proto.go
+3
-1
go/neo/server/storage.go
go/neo/server/storage.go
+3
-0
No files found.
go/neo/connection.go
View file @
35b5e962
...
@@ -47,7 +47,7 @@ import (
...
@@ -47,7 +47,7 @@ import (
// send/receive exchange will be happening in between those 2 connections.
// send/receive exchange will be happening in between those 2 connections.
//
//
// For a node to be able to accept new incoming connection it has to have
// For a node to be able to accept new incoming connection it has to have
// "server" role - see newNodeLink() for details.
// "server" role - see newNodeLink() for details.
XXX might change to everyone is able to accept.
//
//
// A NodeLink has to be explicitly closed, once it is no longer needed.
// A NodeLink has to be explicitly closed, once it is no longer needed.
//
//
...
@@ -92,7 +92,8 @@ type Conn struct {
...
@@ -92,7 +92,8 @@ type Conn struct {
downOnce
sync
.
Once
// shutdown may be called by both Close and nodelink.shutdown
downOnce
sync
.
Once
// shutdown may be called by both Close and nodelink.shutdown
rxerrOnce
sync
.
Once
// rx error is reported only once - then it is link down or closed
rxerrOnce
sync
.
Once
// rx error is reported only once - then it is link down or closed
closed
uint32
// whether Close was called
closed
uint32
// 1 if Close was called
// 2 if this is temp. Conn created to reply "connection refused"
}
}
...
@@ -101,6 +102,10 @@ var ErrLinkDown = errors.New("node link is down") // e.g. due to IO error
...
@@ -101,6 +102,10 @@ var ErrLinkDown = errors.New("node link is down") // e.g. due to IO error
var
ErrLinkNoListen
=
errors
.
New
(
"node link is not listening for incoming connections"
)
var
ErrLinkNoListen
=
errors
.
New
(
"node link is not listening for incoming connections"
)
var
ErrClosedConn
=
errors
.
New
(
"connection is closed"
)
var
ErrClosedConn
=
errors
.
New
(
"connection is closed"
)
// XXX unify LinkError & ConnError -> NetError?
// (think from point of view how user should be handling errors)
// XXX or it is good to be able to distinguish between only conn error vs whole-link error?
// LinkError is usually returned by NodeLink operations
// LinkError is usually returned by NodeLink operations
type
LinkError
struct
{
type
LinkError
struct
{
Link
*
NodeLink
Link
*
NodeLink
...
@@ -276,14 +281,16 @@ func (c *Conn) shutdown() {
...
@@ -276,14 +281,16 @@ func (c *Conn) shutdown() {
// background on the wire not to break node-node link framing.
// background on the wire not to break node-node link framing.
//
//
// It is safe to call Close several times.
// It is safe to call Close several times.
//
// TODO Close on one end must make Recv/Send on another end fail
// (UC: sending []txn-info)
func
(
c
*
Conn
)
Close
()
error
{
func
(
c
*
Conn
)
Close
()
error
{
// adjust nodeLink.connTab
// adjust nodeLink.connTab to have special entry noting this connection is closed.
// (if nodelink was already shut down and connTab=nil - delete will be noop)
// this way serveRecv knows to reply errConnClosed over network if peer
// sends us something over this conn.
c
.
nodeLink
.
connMu
.
Lock
()
c
.
nodeLink
.
connMu
.
Lock
()
delete
(
c
.
nodeLink
.
connTab
,
c
.
connId
)
if
c
.
nodeLink
.
connTab
!=
nil
{
cc
:=
c
.
nodeLink
.
newConn
(
c
.
connId
)
atomic
.
StoreUint32
(
&
cc
.
closed
,
1
)
// note cc.down stays not closed so that send can work
}
c
.
nodeLink
.
connMu
.
Unlock
()
c
.
nodeLink
.
connMu
.
Unlock
()
atomic
.
StoreUint32
(
&
c
.
closed
,
1
)
atomic
.
StoreUint32
(
&
c
.
closed
,
1
)
...
@@ -291,6 +298,8 @@ func (c *Conn) Close() error {
...
@@ -291,6 +298,8 @@ func (c *Conn) Close() error {
return
nil
return
nil
}
}
// ---- receive ----
// Accept waits for and accepts incoming connection on top of node-node link
// Accept waits for and accepts incoming connection on top of node-node link
func
(
nl
*
NodeLink
)
Accept
()
(
c
*
Conn
,
err
error
)
{
func
(
nl
*
NodeLink
)
Accept
()
(
c
*
Conn
,
err
error
)
{
defer
func
()
{
defer
func
()
{
...
@@ -394,9 +403,25 @@ func (nl *NodeLink) serveRecv() {
...
@@ -394,9 +403,25 @@ func (nl *NodeLink) serveRecv() {
}
}
}
}
//
we have not accepted incoming connection - ignore packet
//
connection not accepted - reply "connection refused"
if
conn
==
nil
{
if
conn
==
nil
{
// XXX also log / increment counter?
conn
=
nl
.
newConn
(
connId
)
atomic
.
StoreUint32
(
&
conn
.
closed
,
2
)
// NOTE conn.down stays not closed so that Send can work
nl
.
connMu
.
Unlock
()
go
conn
.
replyNoConn
(
errConnRefused
)
continue
}
switch
atomic
.
LoadUint32
(
&
conn
.
closed
)
{
case
1
:
// connection closed - reply "connection closed"
nl
.
connMu
.
Unlock
()
go
conn
.
replyNoConn
(
errConnClosed
)
continue
case
2
:
// "connection refused" reply is already in progress
nl
.
connMu
.
Unlock
()
nl
.
connMu
.
Unlock
()
continue
continue
}
}
...
@@ -437,6 +462,24 @@ func (nl *NodeLink) serveRecv() {
...
@@ -437,6 +462,24 @@ func (nl *NodeLink) serveRecv() {
}
}
}
}
// ---- network replies for closed / refused connections ----
var
errConnClosed
=
&
Error
{
PROTOCOL_ERROR
,
"connection closed"
}
var
errConnRefused
=
&
Error
{
PROTOCOL_ERROR
,
"connection refused"
}
// replyNoConn sends error message to peer when a packet was sent to closed / nonexistent connection
func
(
c
*
Conn
)
replyNoConn
(
e
Msg
)
{
c
.
Send
(
e
)
// ignore errors
// remove connTab entry if it was temporary conn created only to send errConnRefused
if
e
==
errConnRefused
{
c
.
nodeLink
.
connMu
.
Lock
()
delete
(
c
.
nodeLink
.
connTab
,
c
.
connId
)
c
.
nodeLink
.
connMu
.
Unlock
()
}
}
// ---- transmit ----
// txReq is request to transmit a packet. Result error goes back to errch
// txReq is request to transmit a packet. Result error goes back to errch
type
txReq
struct
{
type
txReq
struct
{
...
...
go/neo/proto.go
View file @
35b5e962
...
@@ -141,8 +141,10 @@ type NodeUUID int32
...
@@ -141,8 +141,10 @@ type NodeUUID int32
// ErrDecodeOverflow is the error returned by neoMsgDecode when decoding hit buffer overflow
// ErrDecodeOverflow is the error returned by neoMsgDecode when decoding hit buffer overflow
var
ErrDecodeOverflow
=
errors
.
New
(
"decode: bufer overflow"
)
var
ErrDecodeOverflow
=
errors
.
New
(
"decode: bufer overflow"
)
// Msg is the interface implemented by
NEO messages to marshal/unmarshal them into/from wire format
// Msg is the interface implemented by
all NEO messages.
type
Msg
interface
{
type
Msg
interface
{
// marshal/unmarshal into/from wire format:
// neoMsgCode returns message code needed to be used for particular message type
// neoMsgCode returns message code needed to be used for particular message type
// on the wire
// on the wire
neoMsgCode
()
uint16
neoMsgCode
()
uint16
...
...
go/neo/server/storage.go
View file @
35b5e962
...
@@ -205,6 +205,9 @@ func (stor *Storage) talkMaster1(ctx context.Context) (err error) {
...
@@ -205,6 +205,9 @@ func (stor *Storage) talkMaster1(ctx context.Context) (err error) {
type
accepted
struct
{
conn
*
neo
.
Conn
;
err
error
}
type
accepted
struct
{
conn
*
neo
.
Conn
;
err
error
}
acceptq
:=
make
(
chan
accepted
)
acceptq
:=
make
(
chan
accepted
)
go
func
()
{
go
func
()
{
// XXX (temp ?) disabled not to let S accept new connections
return
for
{
for
{
conn
,
err
:=
Mlink
.
Accept
()
conn
,
err
:=
Mlink
.
Accept
()
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment