From 3513b0f2613c613a08d6a68963e9e0bf475b3bbc Mon Sep 17 00:00:00 2001 From: sniper91 Date: Thu, 18 Jul 2024 16:28:49 +0800 Subject: [PATCH] set SO_LINGER=0 to tcp connection --- prober/http.go | 17 +++++++++++++++-- prober/tcp.go | 3 +++ 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/prober/http.go b/prober/http.go index d79e8e1c..c21b8a6f 100644 --- a/prober/http.go +++ b/prober/http.go @@ -353,14 +353,27 @@ func ProbeHTTP(ctx context.Context, target string, module config.Module, registr } } } - client, err := pconfig.NewClientFromConfig(httpClientConfig, "http_probe", pconfig.WithKeepAlivesDisabled()) + dialWithLinger := func(ctx context.Context, network, addr string) (net.Conn, error) { + d := &net.Dialer{} + conn, err := d.DialContext(ctx, network, addr) + if err != nil { + return nil, err + } + tcpConn, ok := conn.(*net.TCPConn) + if ok { + tcpConn.SetLinger(0) + return tcpConn, nil + } + return conn, nil + } + client, err := pconfig.NewClientFromConfig(httpClientConfig, "http_probe", pconfig.WithKeepAlivesDisabled(), pconfig.WithDialContextFunc(dialWithLinger)) if err != nil { level.Error(logger).Log("msg", "Error generating HTTP client", "err", err) return false } httpClientConfig.TLSConfig.ServerName = "" - noServerName, err := pconfig.NewRoundTripperFromConfig(httpClientConfig, "http_probe", pconfig.WithKeepAlivesDisabled()) + noServerName, err := pconfig.NewRoundTripperFromConfig(httpClientConfig, "http_probe", pconfig.WithKeepAlivesDisabled(), pconfig.WithDialContextFunc(dialWithLinger)) if err != nil { level.Error(logger).Log("msg", "Error generating HTTP client without ServerName", "err", err) return false diff --git a/prober/tcp.go b/prober/tcp.go index de960db2..aabca20f 100644 --- a/prober/tcp.go +++ b/prober/tcp.go @@ -114,6 +114,9 @@ func ProbeTCP(ctx context.Context, target string, module config.Module, registry level.Error(logger).Log("msg", "Error dialing TCP", "err", err) return false } + if tcpConn, ok := conn.(*net.TCPConn); ok { + tcpConn.SetLinger(0) + } defer conn.Close() level.Info(logger).Log("msg", "Successfully dialed")