[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("[email protected]", "密码")      fmt.Println(err)      for {          time.Sleep(time.Second * 10)          mailboxes := make(chan *imap.MailboxInfo, 20)          go func() {              imapClient.List("", "*", mailboxes)          }()      }  }