forked from yuxh/gearman-go
type assertion with *net.OpError
This commit is contained in:
parent
45a9d7c3e5
commit
f880354a61
@ -4,7 +4,6 @@ package client
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"io"
|
||||
"net"
|
||||
"sync"
|
||||
)
|
||||
@ -62,9 +61,6 @@ func (client *Client) read(length int) (data []byte, err error) {
|
||||
// read until data can be unpacked
|
||||
for i := length; i > 0 || len(data) < minPacketLength; i -= n {
|
||||
if n, err = client.rw.Read(buf); err != nil {
|
||||
if err == io.EOF {
|
||||
err = ErrLostConn
|
||||
}
|
||||
return
|
||||
}
|
||||
data = append(data, buf[0:n]...)
|
||||
@ -83,10 +79,16 @@ func (client *Client) readLoop() {
|
||||
ReadLoop:
|
||||
for client.conn != nil {
|
||||
if data, err = client.read(bufferSize); err != nil {
|
||||
client.err(err)
|
||||
if err == ErrLostConn {
|
||||
if opErr, ok := err.(*net.OpError); ok {
|
||||
if opErr.Timeout() {
|
||||
client.err(err)
|
||||
}
|
||||
if opErr.Temporary() {
|
||||
continue
|
||||
}
|
||||
break
|
||||
}
|
||||
client.err(err)
|
||||
// If it is unexpected error and the connection wasn't
|
||||
// closed by Gearmand, the client should close the conection
|
||||
// and reconnect to job server.
|
||||
|
@ -2,9 +2,7 @@ package worker
|
||||
|
||||
import (
|
||||
"bufio"
|
||||
"io"
|
||||
"net"
|
||||
"strings"
|
||||
"sync"
|
||||
)
|
||||
|
||||
@ -54,7 +52,13 @@ func (a *agent) work() {
|
||||
var data, leftdata []byte
|
||||
for {
|
||||
if data, err = a.read(bufferSize); err != nil {
|
||||
if err == ErrLostConn {
|
||||
if opErr, ok := err.(*net.OpError); ok {
|
||||
if opErr.Timeout() {
|
||||
a.worker.err(err)
|
||||
}
|
||||
if opErr.Temporary() {
|
||||
continue
|
||||
}
|
||||
break
|
||||
}
|
||||
a.worker.err(err)
|
||||
@ -116,16 +120,6 @@ func (a *agent) PreSleep() {
|
||||
a.write(outpack)
|
||||
}
|
||||
|
||||
func isClosed(err error) bool {
|
||||
switch {
|
||||
case err == io.EOF:
|
||||
fallthrough
|
||||
case strings.Contains(err.Error(), "use of closed network connection"):
|
||||
return true
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
// read length bytes from the socket
|
||||
func (a *agent) read(length int) (data []byte, err error) {
|
||||
n := 0
|
||||
@ -133,9 +127,6 @@ func (a *agent) read(length int) (data []byte, err error) {
|
||||
// read until data can be unpacked
|
||||
for i := length; i > 0 || len(data) < minPacketLength; i -= n {
|
||||
if n, err = a.rw.Read(buf); err != nil {
|
||||
if isClosed(err) {
|
||||
err = ErrLostConn
|
||||
}
|
||||
return
|
||||
}
|
||||
data = append(data, buf[0:n]...)
|
||||
|
Loading…
Reference in New Issue
Block a user