GolangNote

Golang笔记

Golang socket 连接、发送、读取超时处理

Permalink

Golang socket 连接、发送、读取超时处理

Go: socket 连接、发送、读取超时处理
1
2
3
4
5
6
7
8
9
10
11
12
13
14
timeOut := 2
// 连接超时
conn, err := net.DialTimeout("tcp", "118.196.43.156:49002", timeOut*time.Second)
// 发送超时
conn.SetWriteDeadline(time.Now().Add(timeOut * time.Second))
// 读取超时
conn.SetReadDeadline(time.Now().Add(timeOut * time.Second))


conn.Write(msg)
reply := make([]byte, 8192)
conn.Read(reply)
fmt.Println("srv reply:" + string(reply))

本文网址: https://golangnote.com/topic/146.html 转摘请注明来源

Related articles

Golang sync.WaitGroup 的 Wait 超时处理

sync.WaitGroup 使用 `Add(1)`、`Done()`、`Wait()`组合来实现多协程等待,如果某一协程未能合理处理错误,导致无法退出,此时需要引入超时机制。下面是一种超时处理方法。...

golang共享数据用Mutex 或 Channel

在go 里,多线程对共享数据的操作一般要使用Mutex 或 Channel 来加锁或隔离通信。下面是一个使用Mutex 和 Channel 比较的例子。...

Golang Web 程序生产环境独立部署示例

一个 web 应用通常是跑在一个前端代理,如 Nginx 后,这样可以方便的在同一个服务器部署多个应用。这里说的独立部署是指让 go web 程序直接暴露在外面,独占 443、80 端口(俗称裸跑)。这样做除了性能有些提高外,更重要的是部署方便。...

Write a Comment to "Golang socket 连接、发送、读取超时处理"

Submit Comment Login
Based on Golang + fastHTTP + sdb | go1.20 Processed in 0ms