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
goroutine 运行机制是不能外部终止,只能通过 channel 来与它通信,通过 channel 给goroutine 发送终止信号...
个人使用中发现,按行读取较大文件 10~100MB ,使用 `ReadSlice()` 比 `scanner.Scan()` 性能好一些。...
sync.WaitGroup 使用 `Add(1)`、`Done()`、`Wait()`组合来实现多协程等待,如果某一协程未能合理处理错误,导致无法退出,此时需要引入超时机制。下面是一种超时处理方法。...
在网络编程中,经常用 http.Post 发送文件到远程服务器,可以通过自己构造 `multipart/form-data; boundary` 来实现。...
推荐几个chrome debug protocol 库,直接面向 chrome debug protocol api...
phantomjs 是个很优秀的软件,虽然现在被chrome headless 抢了风头,但在某些特定场合,使用phantomjs 还是很方便,这里是介绍使用Go 实现动态代理。...
在go 里,多线程对共享数据的操作一般要使用Mutex 或 Channel 来加锁或隔离通信。下面是一个使用Mutex 和 Channel 比较的例子。...
下面是 Golang slice 和 map 的查询性能比较代码...
Bolt 是一个优秀、纯 Go 实现、支持 ACID 事务的嵌入式 Key/Value 数据库。但在使用过程中会有很多空间碎片。一般数据库占用的空间是元数据空间的 1.5~4 倍。Bolt 没有内置的压缩功能,需要手动压缩。...
Go 语言内置的 `sort` 库可以对各种列表排序,这里是按 string slice 里的字符串长度排序。...