[Go] 测试go连接imap的tcp长连接
- 2019 年 11 月 22 日
- 筆記
连接上imap服务后,什么都不操作,我测试大约5分钟会被服务端断掉,测试代码如下
imapClient, _ := client.Dial("imap.sina.net:143") for { time.Sleep(time.Second * 1) }
为了保持住这条连接,每隔10秒列取一下邮件夹列表,这样就可以一直保持住连接了。开三个窗口,一个窗口不停的netstat查看tcp连接情况,一个窗口运行代码,一个窗口打开tcpdump监听端口查看数据请求
while true;do clear;date;netstat -altupn|grep 143;sleep 1;done

tcpdump -i enp0s25 port 143 -vv
可以看到每隔10秒会有数据传输

完整测试代码
package main import ( "fmt" "time" "github.com/emersion/go-imap" "github.com/emersion/go-imap/client" ) func main() { imapClient, _ := client.Dial("imap.sina.net:143") err := imapClient.Login("shihan2@sopans.com", "密码") fmt.Println(err) for { time.Sleep(time.Second * 10) mailboxes := make(chan *imap.MailboxInfo, 20) go func() { imapClient.List("", "*", mailboxes) }() } }