Преглед изворни кода

Deprecate bufferSize

tags/v2.1.3^2
9seconds пре 4 година
родитељ
комит
d19cfb1df4

+ 2
- 4
internal/cli/run_proxy.go Прегледај датотеку

@@ -38,10 +38,9 @@ func makeNetwork(conf *config.Config, version string) (mtglib.Network, error) {
38 38
 	tcpTimeout := conf.Network.Timeout.TCP.Get(network.DefaultTimeout)
39 39
 	httpTimeout := conf.Network.Timeout.HTTP.Get(network.DefaultHTTPTimeout)
40 40
 	dohIP := conf.Network.DOHIP.Get(net.ParseIP(network.DefaultDOHHostname)).String()
41
-	bufferSize := conf.TCPBuffer.Get(network.DefaultBufferSize)
42 41
 	userAgent := "mtg/" + version
43 42
 
44
-	baseDialer, err := network.NewDefaultDialer(tcpTimeout, int(bufferSize))
43
+	baseDialer, err := network.NewDefaultDialer(tcpTimeout, 0)
45 44
 	if err != nil {
46 45
 		return nil, fmt.Errorf("cannot build a default dialer: %w", err)
47 46
 	}
@@ -181,7 +180,6 @@ func runProxy(conf *config.Config, version string) error {
181 180
 		EventStream:     eventStream,
182 181
 
183 182
 		Secret:             conf.Secret,
184
-		BufferSize:         conf.TCPBuffer.Get(mtglib.DefaultBufferSize),
185 183
 		DomainFrontingPort: conf.DomainFrontingPort.Get(mtglib.DefaultDomainFrontingPort),
186 184
 		PreferIP:           conf.PreferIP.Get(mtglib.DefaultPreferIP),
187 185
 
@@ -193,7 +191,7 @@ func runProxy(conf *config.Config, version string) error {
193 191
 		return fmt.Errorf("cannot create a proxy: %w", err)
194 192
 	}
195 193
 
196
-	listener, err := utils.NewListener(conf.BindTo.Get(""), int(opts.BufferSize))
194
+	listener, err := utils.NewListener(conf.BindTo.Get(""), 0)
197 195
 	if err != nil {
198 196
 		return fmt.Errorf("cannot start proxy: %w", err)
199 197
 	}

+ 0
- 4
internal/cli/simple_run.go Прегледај датотеку

@@ -38,10 +38,6 @@ func (s *SimpleRun) Run(cli *CLI, version string) error { // nolint: cyclop
38 38
 		return fmt.Errorf("incorrect concurrency: %w", err)
39 39
 	}
40 40
 
41
-	if err := conf.TCPBuffer.Set(s.TCPBuffer); err != nil {
42
-		return fmt.Errorf("incorrect tcp-buffer: %w", err)
43
-	}
44
-
45 41
 	if err := conf.PreferIP.Set(s.PreferIP); err != nil {
46 42
 		return fmt.Errorf("incorrect prefer-ip: %w", err)
47 43
 	}

+ 0
- 1
internal/config/config.go Прегледај датотеку

@@ -13,7 +13,6 @@ type Config struct {
13 13
 	AllowFallbackOnUnknownDC TypeBool        `json:"allowFallbackOnUnknownDc"`
14 14
 	Secret                   mtglib.Secret   `json:"secret"`
15 15
 	BindTo                   TypeHostPort    `json:"bindTo"`
16
-	TCPBuffer                TypeBytes       `json:"tcpBuffer"`
17 16
 	PreferIP                 TypePreferIP    `json:"preferIp"`
18 17
 	DomainFrontingPort       TypePort        `json:"domainFrontingPort"`
19 18
 	TolerateTimeSkewness     TypeDuration    `json:"tolerateTimeSkewness"`

+ 0
- 1
internal/config/parse.go Прегледај датотеку

@@ -13,7 +13,6 @@ type tomlConfig struct {
13 13
 	AllowFallbackOnUnknownDC bool   `toml:"allow-fallback-on-unknown-dc" json:"allowFallbackOnUnknownDc,omitempty"`
14 14
 	Secret                   string `toml:"secret" json:"secret"`
15 15
 	BindTo                   string `toml:"bind-to" json:"bindTo"`
16
-	TCPBuffer                string `toml:"tcp-buffer" json:"tcpBuffer,omitempty"`
17 16
 	PreferIP                 string `toml:"prefer-ip" json:"preferIp,omitempty"`
18 17
 	DomainFrontingPort       uint   `toml:"domain-fronting-port" json:"domainFrontingPort,omitempty"`
19 18
 	TolerateTimeSkewness     string `toml:"tolerate-time-skewness" json:"tolerateTimeSkewness,omitempty"`

+ 2
- 5
internal/utils/net_listener.go Прегледај датотеку

@@ -9,8 +9,6 @@ import (
9 9
 
10 10
 type Listener struct {
11 11
 	net.Listener
12
-
13
-	bufferSize int
14 12
 }
15 13
 
16 14
 func (l Listener) Accept() (net.Conn, error) {
@@ -19,7 +17,7 @@ func (l Listener) Accept() (net.Conn, error) {
19 17
 		return nil, err // nolint: wrapcheck
20 18
 	}
21 19
 
22
-	if err := network.SetClientSocketOptions(conn, l.bufferSize); err != nil {
20
+	if err := network.SetClientSocketOptions(conn, 0); err != nil {
23 21
 		conn.Close()
24 22
 
25 23
 		return nil, fmt.Errorf("cannot set TCP options: %w", err)
@@ -35,7 +33,6 @@ func NewListener(bindTo string, bufferSize int) (net.Listener, error) {
35 33
 	}
36 34
 
37 35
 	return Listener{
38
-		Listener:   base,
39
-		bufferSize: bufferSize,
36
+		Listener: base,
40 37
 	}, nil
41 38
 }

+ 2
- 0
mtglib/proxy_opts.go Прегледај датотеку

@@ -45,6 +45,8 @@ type ProxyOpts struct {
45 45
 	// buffers: to and from.
46 46
 	//
47 47
 	// This is an optional setting.
48
+	//
49
+	// Deprecated: this setting is no longer makes any effect.
48 50
 	BufferSize uint
49 51
 
50 52
 	// Concurrency is a size of the worker pool for connection management.

+ 5
- 13
network/default.go Прегледај датотеку

@@ -9,8 +9,6 @@ import (
9 9
 
10 10
 type defaultDialer struct {
11 11
 	net.Dialer
12
-
13
-	bufferSize int
14 12
 }
15 13
 
16 14
 func (d *defaultDialer) Dial(network, address string) (net.Conn, error) {
@@ -30,7 +28,7 @@ func (d *defaultDialer) DialContext(ctx context.Context, network, address string
30 28
 	}
31 29
 
32 30
 	// we do not need to call to end user. End users call us.
33
-	if err := SetServerSocketOptions(conn, d.bufferSize); err != nil {
31
+	if err := SetServerSocketOptions(conn, 0); err != nil {
34 32
 		conn.Close()
35 33
 
36 34
 		return nil, fmt.Errorf("cannot set socket options: %w", err)
@@ -44,26 +42,20 @@ func (d *defaultDialer) DialContext(ctx context.Context, network, address string
44 42
 //
45 43
 // The most default one you can imagine. But it has tunes TCP
46 44
 // connections and setups SO_REUSEPORT.
45
+//
46
+// bufferSize is deprecated and ignored. It is kept here for backward
47
+// compatibility.
47 48
 func NewDefaultDialer(timeout time.Duration, bufferSize int) (Dialer, error) {
48 49
 	switch {
49 50
 	case timeout < 0:
50 51
 		return nil, fmt.Errorf("timeout %v should be positive number", timeout)
51
-	case bufferSize < 0:
52
-		return nil, fmt.Errorf("buffer size %d should be positive number", bufferSize)
53
-	}
54
-
55
-	if timeout == 0 {
52
+	case timeout == 0:
56 53
 		timeout = DefaultTimeout
57 54
 	}
58 55
 
59
-	if bufferSize == 0 {
60
-		bufferSize = DefaultBufferSize
61
-	}
62
-
63 56
 	return &defaultDialer{
64 57
 		Dialer: net.Dialer{
65 58
 			Timeout: timeout,
66 59
 		},
67
-		bufferSize: bufferSize,
68 60
 	}, nil
69 61
 }

+ 6
- 0
network/init.go Прегледај датотеку

@@ -33,10 +33,16 @@ const (
33 33
 	// request.
34 34
 	DefaultHTTPTimeout = 10 * time.Second
35 35
 
36
+	// Deprecated:
37
+	//
36 38
 	// DefaultBufferSize defines a TCP buffer size. Both read and write, so
37 39
 	// for real size, please multiply this number by 2.
38 40
 	DefaultBufferSize = 16 * 1024 // 16 kib
39 41
 
42
+	// DefaultTCPKeepAlivePeriod defines a time period between 2
43
+	// consequitive probes.
44
+	DefaultTCPKeepAlivePeriod = 10 * time.Second
45
+
40 46
 	// ProxyDialerOpenThreshold is used for load balancing SOCKS5 dialer
41 47
 	// only.
42 48
 	//

+ 10
- 24
network/sockopts.go Прегледај датотеку

@@ -7,39 +7,25 @@ import (
7 7
 
8 8
 // SetClientSocketOptions tunes a TCP socket that represents a connection to
9 9
 // end user (not Telegram service or fronting domain).
10
+//
11
+// bufferSize setting is deprecated and ignored.
10 12
 func SetClientSocketOptions(conn net.Conn, bufferSize int) error {
11
-	tcpConn := conn.(*net.TCPConn) // nolint: forcetypeassert
12
-
13
-	if err := tcpConn.SetNoDelay(false); err != nil {
14
-		return fmt.Errorf("cannot disable TCP_NO_DELAY: %w", err)
15
-	}
16
-
17
-	return setCommonSocketOptions(tcpConn, bufferSize)
13
+	return setCommonSocketOptions(conn.(*net.TCPConn))
18 14
 }
19 15
 
20 16
 // SetServerSocketOptions tunes a TCP socket that represents a connection to
21 17
 // remote server like Telegram or fronting domain (but not end user).
22 18
 func SetServerSocketOptions(conn net.Conn, bufferSize int) error {
23
-	tcpConn := conn.(*net.TCPConn) // nolint: forcetypeassert
24
-
25
-	if err := tcpConn.SetNoDelay(true); err != nil {
26
-		return fmt.Errorf("cannot enable TCP_NO_DELAY: %w", err)
27
-	}
28
-
29
-	return setCommonSocketOptions(tcpConn, bufferSize)
19
+	return setCommonSocketOptions(conn.(*net.TCPConn))
30 20
 }
31 21
 
32
-func setCommonSocketOptions(conn *net.TCPConn, bufferSize int) error {
33
-	if err := conn.SetReadBuffer(bufferSize); err != nil {
34
-		return fmt.Errorf("cannot set read buffer size: %w", err)
35
-	}
36
-
37
-	if err := conn.SetWriteBuffer(bufferSize); err != nil {
38
-		return fmt.Errorf("cannot set write buffer size: %w", err)
22
+func setCommonSocketOptions(conn *net.TCPConn) error {
23
+	if err := conn.SetKeepAlive(true); err != nil {
24
+		return fmt.Errorf("cannot disable TCP keepalive probes: %w", err)
39 25
 	}
40 26
 
41
-	if err := conn.SetKeepAlive(false); err != nil {
42
-		return fmt.Errorf("cannot disable TCP keepalive probes: %w", err)
27
+	if err := conn.SetKeepAlivePeriod(DefaultTCPKeepAlivePeriod); err != nil {
28
+		return fmt.Errorf("cannot set time period of TCP keepalive probes: %w", err)
43 29
 	}
44 30
 
45 31
 	if err := conn.SetLinger(tcpLingerTimeout); err != nil {
@@ -51,7 +37,7 @@ func setCommonSocketOptions(conn *net.TCPConn, bufferSize int) error {
51 37
 		return fmt.Errorf("cannot get underlying raw connection: %w", err)
52 38
 	}
53 39
 
54
-	if err := setSocketReuseAddrPort(rawConn, bufferSize); err != nil {
40
+	if err := setSocketReuseAddrPort(rawConn); err != nil {
55 41
 		return fmt.Errorf("cannot setup SO_REUSEADDR/PORT: %w", err)
56 42
 	}
57 43
 

+ 1
- 1
network/sockopts_unix.go Прегледај датотеку

@@ -10,7 +10,7 @@ import (
10 10
 	"golang.org/x/sys/unix"
11 11
 )
12 12
 
13
-func setSocketReuseAddrPort(conn syscall.RawConn, bufferSize int) error {
13
+func setSocketReuseAddrPort(conn syscall.RawConn) error {
14 14
 	var err error
15 15
 
16 16
 	conn.Control(func(fd uintptr) { // nolint: errcheck

+ 1
- 1
network/sockopts_windows.go Прегледај датотеку

@@ -5,6 +5,6 @@ package network
5 5
 
6 6
 import "syscall"
7 7
 
8
-func setSocketReuseAddrPort(conn syscall.RawConn, bufferSize int) error {
8
+func setSocketReuseAddrPort(conn syscall.RawConn) error {
9 9
 	return nil
10 10
 }

Loading…
Откажи
Сачувај