前言:
眼前兄弟们对“java线程池最大线程数量多少最合适”可能比较关切,我们都想要剖析一些“java线程池最大线程数量多少最合适”的相关文章。那么小编也在网摘上网罗了一些对于“java线程池最大线程数量多少最合适””的相关内容,希望大家能喜欢,看官们一起来学习一下吧!正文开始前,分享阿里 P8 资深架构师吐血总结的 《Java 核心知识体系&面试资料.pdf》
阿里 P8 级资深架构师吐血总结的一份 Java 核心知识.pdf, 内容覆盖很广,Java 核心基础、Java 多线程、高并发、Spring、微服务、Netty 与 RPC、Zookeeper、Kafka、RabbitMQ、Habase、设计模式、负载均衡、分布式缓存、Hadoop、Spark、Storm、云计算等。
获取方式:【关注 + 转发】后,私信我,回复关键字【资源】,即可免费无套路获取哦~
以下是资源的部分目录以及内容截图:
重要的事再说一遍,获取方式:【关注 + 转发】后,私信我,回复关键字【资源】,即可免费无套路获取哦~
正文开始,show time !
本文系转载,作者:京东/王新栋
一台Java服务器能跑多少个线程?这个问题来自一次线上报警如下图,超过了我们的配置阈值。
图:京东自研UMP监控分析
打出jstack文件,通过IBM Thread and Monitor Dump Analyzer for Java工具查看如下:
图:IBM Thread and Monitor Dump Analyzer for Java
共计1661个线程,和监控数据得出的吻合。但这个数量应该是大了,我们都知道线程多了,就会有线程切换,带来性能开销。
当时就想到一台Java服务器到底可以跑多少个线程呢?跟什么有关系?现整理如下。
每个线程都有一个线程栈空间通过-Xss设置,查了一下我们服务器的关于jvm内存的配置
-Xms4096m-Xmx4096m-XX:MaxPermSize=1024m
只有这三个,并没有-Xss 和-XX:ThreadStackSize的配置,因此是走的默认值。
图:JVM的默认栈大小
可以通过如下命令打印输出默认值的大小,命令:
jinfo -flag ThreadStackSize
例如:
[root@host-192-168-202-229 ~]#jinfo -flag ThreadStackSize 1807-XX:ThreadStackSize=1024
不考虑系统限制,可以通过如下公式计算,得出最大线程数量。
线程数量 =(机器本身可用内存 - JVM分配的堆内存)/ Xss的值,比如我们的容器本身大小是8G,堆大小是4096M,-Xss默认值,可以得出最大线程数量:4096个。
根据计算公式,得出如下结论:
结论1:jvm堆越大,系统创建的线程数量越小。结论2:当-Xss的值越小,可生成线程数量越多。
我们知道操作系统分配给每个进程的内存大小是有限制的,比如32位的Windows是2G。因此操作系统对一个进程下的线程数量是有限制的,不能无限的增多。经验值:3000-5000左右(我没有验证)。
刚才说的是不考虑系统限制的情况,那如果考虑系统限制呢,主要跟以下几个参数有关系:
/proc/sys/kernel/pid_max 增大,线程数量增大,pid_max有最高值,超过之后不再改变,而且32,64位也不一样/proc/sys/kernel/thread-max 系统可以生成最大线程数量max_user_process(ulimit -u)centos系统上才有,没有具体研究/proc/sys/vm/max_map_count 增大,数量增多
线程是非常宝贵的资源,我们要严格控制线程的数量,像上面我们的截图情况,显然线程数量过多。这个是跟我们自己配置了fixed大小的线程池有关系。京东有自己的rpc框架jsf,里面可以针对每个服务端口设置线程大小。
标签: #java线程池最大线程数量多少最合适