fix:udp buf

pull/413/head
cnlh 2020-02-17 02:30:34 +08:00
parent 1fec6c3649
commit 05c27b9365
1 changed files with 39 additions and 20 deletions

View File

@ -1,8 +1,11 @@
package proxy package proxy
import ( import (
"io"
"net" "net"
"strings" "strings"
"sync"
"time"
"ehang.io/nps/bridge" "ehang.io/nps/bridge"
"ehang.io/nps/lib/common" "ehang.io/nps/lib/common"
@ -13,6 +16,7 @@ import (
type UdpModeServer struct { type UdpModeServer struct {
BaseServer BaseServer
addrMap sync.Map
listener *net.UDPConn listener *net.UDPConn
} }
@ -33,8 +37,8 @@ func (s *UdpModeServer) Start() error {
if err != nil { if err != nil {
return err return err
} }
buf := common.BufPoolUdp.Get().([]byte)
for { for {
buf := common.BufPoolUdp.Get().([]byte)
n, addr, err := s.listener.ReadFromUDP(buf) n, addr, err := s.listener.ReadFromUDP(buf)
if err != nil { if err != nil {
if strings.Contains(err.Error(), "use of closed network connection") { if strings.Contains(err.Error(), "use of closed network connection") {
@ -49,6 +53,13 @@ func (s *UdpModeServer) Start() error {
} }
func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) { func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
if v, ok := s.addrMap.Load(addr.String()); ok {
clientConn, ok := v.(io.ReadWriteCloser)
if ok {
clientConn.Write(data)
s.task.Flow.Add(int64(len(data)), 0)
}
} else {
if err := s.CheckFlowAndConnNum(s.task.Client); err != nil { if err := s.CheckFlowAndConnNum(s.task.Client); err != nil {
logs.Warn("client id %d, task id %d,error %s, when udp connection", s.task.Client.Id, s.task.Id, err.Error()) logs.Warn("client id %d, task id %d,error %s, when udp connection", s.task.Client.Id, s.task.Id, err.Error())
return return
@ -59,13 +70,19 @@ func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
return return
} else { } else {
target := conn.GetConn(clientConn, s.task.Client.Cnf.Crypt, s.task.Client.Cnf.Compress, nil, true) target := conn.GetConn(clientConn, s.task.Client.Cnf.Crypt, s.task.Client.Cnf.Compress, nil, true)
s.addrMap.Store(addr.String(), target)
defer target.Close() defer target.Close()
s.task.Flow.Add(int64(len(data)), 0)
target.Write(data)
buf := common.BufPoolUdp.Get().([]byte) buf := common.BufPoolUdp.Get().([]byte)
defer common.BufPoolUdp.Put(buf) defer common.BufPoolUdp.Put(buf)
target.Write(data)
s.task.Flow.Add(int64(len(data)), 0) s.task.Flow.Add(int64(len(data)), 0)
for {
clientConn.SetReadDeadline(time.Now().Add(time.Minute * 10))
if n, err := target.Read(buf); err != nil { if n, err := target.Read(buf); err != nil {
s.addrMap.Delete(addr.String())
logs.Warn(err) logs.Warn(err)
return return
} else { } else {
@ -74,6 +91,8 @@ func (s *UdpModeServer) process(addr *net.UDPAddr, data []byte) {
} }
} }
} }
}
}
func (s *UdpModeServer) Close() error { func (s *UdpModeServer) Close() error {
return s.listener.Close() return s.listener.Close()