mirror of
				https://github.com/ehang-io/nps
				synced 2025-10-26 22:45:45 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			74 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package goroutine
 | |
| 
 | |
| import (
 | |
| 	"github.com/cnlh/nps/lib/common"
 | |
| 	"github.com/cnlh/nps/lib/file"
 | |
| 	"github.com/panjf2000/ants/v2"
 | |
| 	"io"
 | |
| 	"net"
 | |
| 	"sync"
 | |
| )
 | |
| 
 | |
| type connGroup struct {
 | |
| 	src io.ReadWriteCloser
 | |
| 	dst io.ReadWriteCloser
 | |
| 	wg  *sync.WaitGroup
 | |
| 	n   *int64
 | |
| }
 | |
| 
 | |
| func newConnGroup(dst, src io.ReadWriteCloser, wg *sync.WaitGroup, n *int64) connGroup {
 | |
| 	return connGroup{
 | |
| 		src: src,
 | |
| 		dst: dst,
 | |
| 		wg:  wg,
 | |
| 		n:   n,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func copyConnGroup(group interface{}) {
 | |
| 	cg, ok := group.(connGroup)
 | |
| 	if !ok {
 | |
| 		return
 | |
| 	}
 | |
| 	var err error
 | |
| 	*cg.n, err = common.CopyBuffer(cg.dst, cg.src)
 | |
| 	if err != nil {
 | |
| 		cg.src.Close()
 | |
| 		cg.dst.Close()
 | |
| 		//logs.Warn("close npc by copy from nps", err, c.connId)
 | |
| 	}
 | |
| 	cg.wg.Done()
 | |
| }
 | |
| 
 | |
| type Conns struct {
 | |
| 	conn1 io.ReadWriteCloser // mux connection
 | |
| 	conn2 net.Conn           // outside connection
 | |
| 	flow  *file.Flow
 | |
| }
 | |
| 
 | |
| func NewConns(c1 io.ReadWriteCloser, c2 net.Conn, flow *file.Flow) Conns {
 | |
| 	return Conns{
 | |
| 		conn1: c1,
 | |
| 		conn2: c2,
 | |
| 		flow:  flow,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func copyConns(group interface{}) {
 | |
| 	conns := group.(Conns)
 | |
| 	wg := new(sync.WaitGroup)
 | |
| 	wg.Add(2)
 | |
| 	var in, out int64
 | |
| 	_ = connCopyPool.Invoke(newConnGroup(conns.conn1, conns.conn2, wg, &in))
 | |
| 	// outside to mux : incoming
 | |
| 	_ = connCopyPool.Invoke(newConnGroup(conns.conn2, conns.conn1, wg, &out))
 | |
| 	// mux to outside : outgoing
 | |
| 	wg.Wait()
 | |
| 	if conns.flow != nil {
 | |
| 		conns.flow.Add(in, out)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| var connCopyPool, _ = ants.NewPoolWithFunc(200000, copyConnGroup, ants.WithNonblocking(false))
 | |
| var CopyConnsPool, _ = ants.NewPoolWithFunc(100000, copyConns, ants.WithNonblocking(false))
 | 
