fix: Ignore logging some tcp routine errors (#5097)

This commit is contained in:
A. Elleuch 2017-11-28 22:51:17 +01:00 committed by Harshavardhana
parent 6923630389
commit 98d07210e7
2 changed files with 14 additions and 7 deletions

View File

@ -23,6 +23,7 @@ import (
"io"
"net"
"net/http"
"os"
"strings"
"sync"
"syscall"
@ -89,13 +90,19 @@ type httpListener struct {
errorLogFunc func(error, string, ...interface{}) // function to be called on errors.
}
// ignoreErr returns true if error is due to a network timeout or
// io.EOF and false otherwise
func ignoreErr(err error) bool {
// isRoutineNetErr returns true if error is due to a network timeout,
// connect reset or io.EOF and false otherwise
func isRoutineNetErr(err error) bool {
if nErr, ok := err.(*net.OpError); ok {
// Check if the error is a tcp connection reset
if syscallErr, ok := nErr.Err.(*os.SyscallError); ok {
if errno, ok := syscallErr.Err.(syscall.Errno); ok {
return errno == syscall.ECONNRESET
}
}
// Check if the error is a timeout
return nErr.Timeout()
}
return err == io.EOF
}
@ -138,7 +145,7 @@ func (listener *httpListener) start() {
// speed up loading of a web page. Peek may also fail due to network
// saturation on a transport with read timeout set. All other kind of
// errors should be logged for further investigation. Thanks @brendanashworth.
if !ignoreErr(err) {
if !isRoutineNetErr(err) {
listener.errorLogFunc(err,
"Error in reading from new connection %s at server %s",
bufconn.RemoteAddr(), bufconn.LocalAddr())
@ -182,7 +189,7 @@ func (listener *httpListener) start() {
// Peek bytes of maximum length of all HTTP methods.
data, err := bufconn.Peek(methodMaxLen)
if err != nil {
if listener.errorLogFunc != nil {
if !isRoutineNetErr(err) && listener.errorLogFunc != nil {
listener.errorLogFunc(err,
"Error in reading from new TLS connection %s at server %s",
bufconn.RemoteAddr(), bufconn.LocalAddr())

View File

@ -826,7 +826,7 @@ func TestIgnoreErr(t *testing.T) {
}
for i, tc := range testCases {
if actual := ignoreErr(tc.err); actual != tc.want {
if actual := isRoutineNetErr(tc.err); actual != tc.want {
t.Errorf("Test case %d: Expected %v but got %v for %v", i+1,
tc.want, actual, tc.err)
}