求助:golang 并发发起TCP连接 导致 accept卡住

dp1993132 · 2019-12-16 23:07:20 · 2636 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2019-12-16 23:07:20 的主题,其中的信息可能已经有所发展或是发生改变。

测试用例代码如下

并发发起2000个连接会出现 accept卡死的情况

只有drawin和linux系统会有这个问题,windows正常

func TestStressConn3(t *testing.T) {
    const max = 2000
    var number = 0
    l, _ := net.Listen("tcp4", "127.0.0.1:9003")
    wg := sync.WaitGroup{}
    wg.Add(max)

    for i := 0; i < max; i++ {
        go func() {
            t.Log("start conn")
            net.Dial("tcp4", "127.0.0.1:9003")
            t.Log("end conn")
        }()
    }
    go func() {
        for {
            number++
            fmt.Println("accept", time.Now().String())
            l.Accept()
            fmt.Println("end", time.Now().String(), number)
            wg.Done()
        }
    }()
    tm := time.Now()
    wg.Wait()
    t.Log("用时", time.Now().Sub(tm).Seconds())
}

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2636 次点击  
加入收藏 微博
4 回复  |  直到 2019-12-17 11:58:23
saberlong
saberlong · #1 · 5年之前

并不会。应该是你的系统设置问题。默认情况下很多linux发行版的用户最大句柄数为1024,需要自己设置。

dp1993132
dp1993132 · #2 · 5年之前

单进程最多打开文件数已经设置到10240了,之前有到过最大句柄数,所以提前有设置。达到最大句柄会报错open many files。但是这个用例没有报错,直接卡在了中间

saberlong
saberlong · #3 · 5年之前

@dp1993132 同样的用例,在我的系统上没有问题。archlinux, go1.13.5。tcpdump监控下tcp握手的情况,看看有没有头绪

dp1993132
dp1993132 · #4 · 5年之前
saberlongsaberlong #3 回复

@dp1993132 同样的用例,在我的系统上没有问题。archlinux, go1.13.5。tcpdump监控下tcp握手的情况,看看有没有头绪

好的,谢谢。我再看看系统参数的影响

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传