V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
ayonel
V2EX  ›  程序员

请教各位大佬一个关于多线程的问题, RT

  •  
  •   ayonel · Sep 17, 2018 · 3044 views
    This topic created in 2790 days ago, the information mentioned may be changed or developed.

    最近跟一个同事聊天时,同事说之前在某 BAT 大厂实习后台开发时,做一个接口如果用多线程,数量都是 4000 个线程起,我对此表示怀疑。因为据我的认知,线程数量一般开到 CPU 核心数最好,最好不要超过 2 倍 CPU 核心数。因此,想请教下给为大佬,实际生产中用到的高并发的情况,真的能开这么多线程吗?

    9 replies    2018-09-20 11:59:12 +08:00
    brucewuio
        1
    brucewuio  
       Sep 17, 2018
    人家都说后台 服务器跑 又不是你家 i7 跑
    A555
        2
    A555  
       Sep 17, 2018
    真的能开这么多线程吗?

    堆机器
    AaronLiu00
        3
    AaronLiu00  
    PRO
       Sep 17, 2018 via Android
    lz 也是多线程发帖
    opengps
        4
    opengps  
       Sep 17, 2018 via Android
    这种说法确实有,但我感觉离谱了,不是密集占用 cpu 完全可以开更多线程
    simonliu2018
        5
    simonliu2018  
       Sep 17, 2018
    我没见过这么强劲的计算机。

    线程数一般是 CPU 核心数稍微多点,预期部分线程会等待 IO 空出 CPU 给其他线程用。
    linshuang
        6
    linshuang  
       Sep 17, 2018
    你说的是有道理的,那货在吹水
    LokiSharp
        7
    LokiSharp  
       Sep 17, 2018
    这个贴子也是多线程的 Emmmmm
    PazuLee
        8
    PazuLee  
       Sep 17, 2018
    真不是吹水。。。其实得看线程状态,所谓开 4000 线程,不一定都是 runnable ;假设一 64c128g 物理机虚 8 台 vm 不过分吧,每台 vm 上开个 tomcat 或者 netty,total thread 确实可能在 500-800,这么算总数的话,其实就能到 4000 ;但是每个 netty 上实际工作的线程可能很少,大概几十。
    ayonel
        9
    ayonel  
    OP
       Sep 20, 2018
    @LokiSharp 不好意思,刚注册 V2EX 不就,还不是很熟悉,手抖发了两遍
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3231 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 14:17 · PVG 22:17 · LAX 07:17 · JFK 10:17
    ♥ Do have faith in what you're doing.