diff --git a/client/proxy/xtcp.go b/client/proxy/xtcp.go index 4ba8d50c..e6c76203 100644 --- a/client/proxy/xtcp.go +++ b/client/proxy/xtcp.go @@ -137,7 +137,7 @@ func (pxy *XTCPProxy) listenByKCP(listenConn *net.UDPConn, raddr *net.UDPAddr, s fmuxCfg := fmux.DefaultConfig() fmuxCfg.KeepAliveInterval = 10 * time.Second - fmuxCfg.MaxStreamWindowSize = 2 * 1024 * 1024 + fmuxCfg.MaxStreamWindowSize = 6 * 1024 * 1024 fmuxCfg.LogOutput = io.Discard session, err := fmux.Server(remote, fmuxCfg) if err != nil { diff --git a/client/service.go b/client/service.go index 0849484c..df85c05f 100644 --- a/client/service.go +++ b/client/service.go @@ -396,6 +396,7 @@ func (cm *ConnectionManager) OpenConnection() error { fmuxCfg := fmux.DefaultConfig() fmuxCfg.KeepAliveInterval = time.Duration(cm.cfg.TCPMuxKeepaliveInterval) * time.Second fmuxCfg.LogOutput = io.Discard + fmuxCfg.MaxStreamWindowSize = 6 * 1024 * 1024 session, err := fmux.Client(conn, fmuxCfg) if err != nil { return err diff --git a/client/visitor/xtcp.go b/client/visitor/xtcp.go index 73f30789..8dcd9363 100644 --- a/client/visitor/xtcp.go +++ b/client/visitor/xtcp.go @@ -351,7 +351,7 @@ func (ks *KCPTunnelSession) Init(listenConn *net.UDPConn, raddr *net.UDPAddr) er fmuxCfg := fmux.DefaultConfig() fmuxCfg.KeepAliveInterval = 10 * time.Second - fmuxCfg.MaxStreamWindowSize = 2 * 1024 * 1024 + fmuxCfg.MaxStreamWindowSize = 6 * 1024 * 1024 fmuxCfg.LogOutput = io.Discard session, err := fmux.Client(remote, fmuxCfg) if err != nil { diff --git a/server/service.go b/server/service.go index e67ee73d..3c4f5a81 100644 --- a/server/service.go +++ b/server/service.go @@ -461,6 +461,7 @@ func (svr *Service) HandleListener(l net.Listener) { fmuxCfg := fmux.DefaultConfig() fmuxCfg.KeepAliveInterval = time.Duration(svr.cfg.TCPMuxKeepaliveInterval) * time.Second fmuxCfg.LogOutput = io.Discard + fmuxCfg.MaxStreamWindowSize = 6 * 1024 * 1024 session, err := fmux.Server(frpConn, fmuxCfg) if err != nil { log.Warn("Failed to create mux connection: %v", err)