Вам необходимо создать свой собственный net.Dialer
, который возвращает net.Conn
, который устанавливает соответствующие сроки чтения и записи.
Conn
будет выглядеть примерно так:
// Conn wraps a net.Conn, and sets a deadline for every read
// and write operation.
type Conn struct {
net.Conn
ReadTimeout time.Duration
WriteTimeout time.Duration
}
func (c *Conn) Read(b []byte) (int, error) {
err := c.Conn.SetReadDeadline(time.Now().Add(c.ReadTimeout))
if err != nil {
return 0, err
}
return c.Conn.Read(b)
}
func (c *Conn) Write(b []byte) (int, error) {
err := c.Conn.SetWriteDeadline(time.Now().Add(c.WriteTimeout))
if err != nil {
return 0, err
}
return c.Conn.Write(b)
}
Некоторые соответствующие ссылки: http://blog.golang.org/go-concurrency-patterns-timing-out-and и https: // gobyexample. com/таймаут – Simon