最佳线程数:

性能压测的情况下,起初随着用户数的增加,QPS会上升,当到了一定的阀值之后,用户数量增加QPS并不会增加,或者增加不明显,同时请求的响应时间却大幅增加。这个阀值我们认为是最佳线程数。

为什么要找最佳线程数

1.过多的线程只会造成,更多的内存开销,更多的CPU开销,但是对提升QPS确毫无帮助

2.找到最佳线程数后通过简单的设置,可以让web系统更加稳定,得到最高,最稳定的QPS输出

最佳线程数的获取:

1、通过用户慢慢递增来进行性能压测,观察QPS,响应时间

2、根据公式计算:服务器端最佳线程数量=((线程等待时间+线程cpu时间)/线程cpu时间) * cpu数量

3、单用户压测,查看CPU的消耗,然后直接乘以百分比,再进行压测,一般这个值的附近应该就是最佳线程数量。

影响最佳线程数的主要因素:

1、IO

2、CPU

根据公式:服务器端最佳线程数量=((线程等待时间+线程cpu时间)/线程cpu时间) * cpu数量

一般来说是IO和CPU。IO开销较多的应用其CPU线程等待时间会比较长,所以线程数量可以开的多一些,相反则线程数量要少一些,其实有两种极端,纯IO的应用,比如proxy,则线程数量可以开到非常大(实在太大了则需要考虑线程切换的开销),这种应用基本上后端(比如这个proxy是代理搜索的)的QPS能有多少,proxy就有多少。

另一种是耗CPU的计算,这种情况一般来讲只能开到CPU个数的线程数量。但是并不是说这种应用的QPS就不高,往往这种应用的QPS可以很高。

QPS和线程数的关系

1、在最佳线程数量之前,QPS和线程是互相递增的关系,线程数量到了最佳线程之后,QPS持平,不在上升,甚至略有下降,同时相应时间持续上升。

2、同一个系统而言,支持的线程数越多(最佳线程数越多而不是配置的线程数越多),QPS越高

QPS和响应时间的关系

1、对于一般的web系统,响应时间一般有CPU执行时间+IO等待时间组成

2、CPU的执行时间减少,对QPS有实质的提升,IO时间的减少,对QPS提升不明显。如果要想明显提升QPS,优化系统的时候要着重优化CPU消耗大户。

最佳线程数和jvm堆内存得关系:

以上都是依据性能瓶颈在CPU的情况,对于java应用还有一个因素是FULL GC,我们要保证在最佳线程数量下,不会发生频繁FULL GC

根据公式::(小GC时间间隔/rt)*(并发线程数量 * thm) <=young 计算得到的并发线程数量如果<最佳线程数量 则可能导致FULL GC较频繁,实际情况看来这种情况在web系统上非常少。不过可以模拟出来。

所以我们在设置jboss线程的时候,可以利用内存公式计算出来的线程数量来设置,通过压测和计算得到最佳线程数,然后设置线程数。

设置线程数量:

压测最佳线程数<真实设置的线程数量<内存极限线程数

比如,通过压测得到某系统的最佳线程数量是10,然后通过内存计算的线程数量是20,则,设置jboss的线程数量为15是可行的,如果直接设置了10,由于系统本身会受到一些依赖系统的变化而产生一些变化,比如系统依赖一些IO的响应时间会突然延长,由于线程数量还是10,其实这个时候最佳线程数量已经变成了13了,由于我们设置死了10,其结果就是导致qps下降,但是如果超过20,则又会引起FULL gc非常频繁,反过来影响QPS的下降。

jboss的线程数设置:

对于jboss而言,设置线程数量要看使用了那种线程连接,如http、ajp等

http和ajp的设置是完全一样的,非常简单:

以ajp为例,找到server.xml或者tomcat-server.xml:

默认线程数量是200个

<Connector port="8009" address="${jboss.bind.address}" connectionTimeout="15000" protocol="AJP/1.3" maxThreads="200" minSpareThreads="40" maxSpareThreads="75" maxPostSize="512000" acceptCount="300" bufferSize="16384" emptySessionPath="false" enableLookups="false" redirectPort="8443" useBodyEncodingForURI="true"/>

这里将默认的线程数量改成了20,当然相应的其他最小空闲线程数和最大空闲线程数也做一下调整:

<Connector port="8009" address="${jboss.bind.address}" connectionTimeout="15000" protocol="AJP/1.3" maxThreads="20" minSpareThreads="20" maxSpareThreads="20" maxPostSize="512000" acceptCount="300" bufferSize="16384" emptySessionPath="false" enableLookups="false" redirectPort="8443" useBodyEncodingForURI="true"/>

linux最佳线程数相关推荐

  1. 最佳线程数 6666 epoll触发量

    --------------------------------------- QPS是每秒钟处理完请求的次数. 响应时间即RT QPS和RT的关系 --------单线程场景 假设我们的服务端只有一 ...

  2. 关于最佳线程数的计算的准确理解

    Venkat Subramaniam 博士在<Programming Concurrency on the JVM>中提到关于最优线程数的计算: The minimum number of ...

  3. Linux最大线程数限制及当前线程数查询

    Linux最大线程数限制及当前线程数查询 1.总结系统限制有: /proc/sys/kernel/pid_max #查系统支持的最大线程数,一般会很大,相当于理论值 /proc/sys/kernel/ ...

  4. 最佳线程数和QPS以及RT

    最近学习性能优化方面的东西,所以,总结一下: 名词解释 QPS:系统每秒处理的请求数(query per second) RT:系统的响应时间,一个请求的响应时间,也可以是一段时间的平均值. 最佳线程 ...

  5. 技术派-关于最佳线程数的计算的准确理解

    Venkat Subramaniam 博士在<Programming Concurrency on the JVM>中提到关于最优线程数的计算: The minimum number of ...

  6. linux支持的最大线程数,Linux最大线程数限制

    开始以为是内存不足导致无法创建线程,把jvm的-Xms,-Xmx的2个参数都加大一倍:-Xms2048m -Xmx2048m.把-Xss参数调小,还是启动失败.应该是系统方面的限制了,这台机器上搞了1 ...

  7. linux 查看线程数的方法

    1.通过/proc伪文件系统 cat /proc/{pid}/status 其中Threads后面跟的就是线程数. 或者:通过 ls /proc/{pid}/task | wc -l 2.使用top命 ...

  8. java统计系统线程数_Java并发(八)计算线程池最佳线程数

    目录 一.理论分析 二.实际应用 为了加快程序处理速度,我们会将问题分解成若干个并发执行的任务.并且创建线程池,将任务委派给线程池中的线程,以便使它们可以并发地执行.在高并发的情况下采用线程池,可以有 ...

  9. Linux 用户线程数与文件句柄树调整(nproc与nofile的问题)

    2019独角兽企业重金招聘Python工程师标准>>> 调整注意:尽量不要使用 root 用户来部署应用程序,避免资源耗尽后无法登录操作系统.  普通用户的线程数限制值要看可用物理内 ...

最新文章

  1. AutoML Vision教程:训练模型解决计算机视觉问题,准确率达94.5%
  2. c++读取txt文件中的数字_在Python中读取包中的数据文件的三种方式
  3. 3.15 排列对称串
  4. FullCalendar 二:FullCalendar日历插件说明文档
  5. Android的xml/assets/raw资源使用具体解释
  6. 在VC资源文件中加入声音资源
  7. Linux学习笔记---使用tftp命令下载文件
  8. 台式计算机计量单位,计算机常见计量单位解析
  9. 马斯克辞任董事长,罚款2000万美元,钢铁侠一夜服软
  10. springboot使用@Async实现异步操作
  11. 阵列信号处理-学习笔记002
  12. python怎么写入txt文件_python 如何将数据写入本地txt文本文件的实现方法
  13. mysql查询各科成绩前三名_mysql巧用连表查询各科成绩前三名
  14. 微信公众平台接口测试账号申请
  15. Python中的any函数
  16. HNOI2004 宠物收养所
  17. MAS移动行业应用解决方案
  18. C++ VS2019 缓存区溢出和读取数据无效的警告
  19. Windows下编译MICO源代码遇到的问题
  20. Python 简介及开发环境搭建

热门文章

  1. Java怎么学,Java学习路线,程序员由浅到深学习之路
  2. 阿黛尔 优秀的两首音乐作品(live)
  3. python删除列_python删掉数据表几列的方法
  4. python+unittest框架 UI自动化设计思路以及代码剖析,增加易用性
  5. 301与302的区别,301的坑
  6. tf.nn.sampled_softmax_loss
  7. 机器学习_线性回归_回归系数
  8. 关于管理经济学的有趣解释
  9. PowerDesigner概念设计模型(CDM)和E-R图
  10. 对www.xici.net西祠胡同自动登陆的参数分析