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

2018-09-17 14:26:33 +08:00
 ayonel

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

2345 次点击
所在节点    程序员
9 条回复
brucewuio
2018-09-17 14:37:47 +08:00
人家都说后台 服务器跑 又不是你家 i7 跑
A555
2018-09-17 14:44:01 +08:00
真的能开这么多线程吗?

堆机器
AaronLiu00
2018-09-17 14:45:00 +08:00
lz 也是多线程发帖
opengps
2018-09-17 14:46:01 +08:00
这种说法确实有,但我感觉离谱了,不是密集占用 cpu 完全可以开更多线程
simonliu2018
2018-09-17 14:46:19 +08:00
我没见过这么强劲的计算机。

线程数一般是 CPU 核心数稍微多点,预期部分线程会等待 IO 空出 CPU 给其他线程用。
linshuang
2018-09-17 14:49:41 +08:00
你说的是有道理的,那货在吹水
LokiSharp
2018-09-17 15:15:59 +08:00
这个贴子也是多线程的 Emmmmm
PazuLee
2018-09-17 16:41:00 +08:00
真不是吹水。。。其实得看线程状态,所谓开 4000 线程,不一定都是 runnable ;假设一 64c128g 物理机虚 8 台 vm 不过分吧,每台 vm 上开个 tomcat 或者 netty,total thread 确实可能在 500-800,这么算总数的话,其实就能到 4000 ;但是每个 netty 上实际工作的线程可能很少,大概几十。
ayonel
2018-09-20 11:59:12 +08:00
@LokiSharp 不好意思,刚注册 V2EX 不就,还不是很熟悉,手抖发了两遍

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/490075

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX