mirror of
https://github.com/cwinfo/yggdrasil-go.git
synced 2024-11-10 05:10:26 +00:00
slightly better way for the tcp sender goroutine(s) to block waiting for work
This commit is contained in:
parent
fd074a4364
commit
0021f3463f
@ -242,7 +242,7 @@ func (iface *tcpInterface) handler(sock net.Conn, incoming bool) {
|
|||||||
in := func(bs []byte) {
|
in := func(bs []byte) {
|
||||||
p.handlePacket(bs)
|
p.handlePacket(bs)
|
||||||
}
|
}
|
||||||
out := make(chan []byte, 32) // TODO? what size makes sense
|
out := make(chan []byte, 1)
|
||||||
defer close(out)
|
defer close(out)
|
||||||
go func() {
|
go func() {
|
||||||
var shadow int64
|
var shadow int64
|
||||||
@ -255,13 +255,17 @@ func (iface *tcpInterface) handler(sock net.Conn, incoming bool) {
|
|||||||
shadow++
|
shadow++
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
send := func(msg []byte) {
|
send := make(chan []byte)
|
||||||
msgLen := wire_encode_uint64(uint64(len(msg)))
|
defer close(send)
|
||||||
buf := net.Buffers{tcp_msg[:], msgLen, msg}
|
go func() {
|
||||||
buf.WriteTo(sock)
|
for msg := range send {
|
||||||
atomic.AddUint64(&p.bytesSent, uint64(len(tcp_msg)+len(msgLen)+len(msg)))
|
msgLen := wire_encode_uint64(uint64(len(msg)))
|
||||||
util_putBytes(msg)
|
buf := net.Buffers{tcp_msg[:], msgLen, msg}
|
||||||
}
|
buf.WriteTo(sock)
|
||||||
|
atomic.AddUint64(&p.bytesSent, uint64(len(tcp_msg)+len(msgLen)+len(msg)))
|
||||||
|
util_putBytes(msg)
|
||||||
|
}
|
||||||
|
}()
|
||||||
timerInterval := tcp_timeout * 2 / 3
|
timerInterval := tcp_timeout * 2 / 3
|
||||||
timer := time.NewTimer(timerInterval)
|
timer := time.NewTimer(timerInterval)
|
||||||
defer timer.Stop()
|
defer timer.Stop()
|
||||||
@ -278,9 +282,9 @@ func (iface *tcpInterface) handler(sock net.Conn, incoming bool) {
|
|||||||
timer.Reset(timerInterval)
|
timer.Reset(timerInterval)
|
||||||
select {
|
select {
|
||||||
case _ = <-timer.C:
|
case _ = <-timer.C:
|
||||||
send(nil) // TCP keep-alive traffic
|
send <- nil // TCP keep-alive traffic
|
||||||
case msg := <-p.linkOut:
|
case msg := <-p.linkOut:
|
||||||
send(msg)
|
send <- msg
|
||||||
case msg, ok := <-out:
|
case msg, ok := <-out:
|
||||||
if !ok {
|
if !ok {
|
||||||
return
|
return
|
||||||
@ -288,31 +292,32 @@ func (iface *tcpInterface) handler(sock net.Conn, incoming bool) {
|
|||||||
put(msg)
|
put(msg)
|
||||||
}
|
}
|
||||||
for len(stack) > 0 {
|
for len(stack) > 0 {
|
||||||
|
// First make sure linkOut gets sent first, if it's non-empty
|
||||||
select {
|
select {
|
||||||
case msg := <-p.linkOut:
|
case msg := <-p.linkOut:
|
||||||
send(msg)
|
send <- msg
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
// Then block until we send or receive something
|
||||||
|
select {
|
||||||
|
case msg := <-p.linkOut:
|
||||||
|
send <- msg
|
||||||
case msg, ok := <-out:
|
case msg, ok := <-out:
|
||||||
if !ok {
|
if !ok {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
put(msg)
|
put(msg)
|
||||||
default:
|
case send <- stack[len(stack)-1]:
|
||||||
msg := stack[len(stack)-1]
|
|
||||||
stack = stack[:len(stack)-1]
|
stack = stack[:len(stack)-1]
|
||||||
send(msg)
|
|
||||||
p.updateQueueSize(-1)
|
p.updateQueueSize(-1)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
p.out = func(msg []byte) {
|
p.out = func(msg []byte) {
|
||||||
|
p.updateQueueSize(1)
|
||||||
defer func() { recover() }()
|
defer func() { recover() }()
|
||||||
select {
|
out <- msg
|
||||||
case out <- msg:
|
|
||||||
p.updateQueueSize(1)
|
|
||||||
default:
|
|
||||||
util_putBytes(msg)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
p.close = func() { sock.Close() }
|
p.close = func() { sock.Close() }
|
||||||
setNoDelay(sock, true)
|
setNoDelay(sock, true)
|
||||||
|
Loading…
Reference in New Issue
Block a user