网站首页 > 技术教程 正文
说明:一般线程与虚拟内存JVM设置同步设置,两者存在对应关系。
1.线程概念说明
maxThreads:此连接器将创建的请求处理线程的最大数量, 即可以处理的同时请求的最大数量,默认值为200。
minSpareThreads:终保持运行状态的最小线程数。 这包括活动线程和空闲线程。 如果未指定,则使用默认值10。
maxConnections: 服务器在任何给定时间将接受和处理的最大连接数。 对于BIO,除非使用执行程序,否则默认值为maxThreads的值,在这种情况下,默认值为执行程序的maxThreads的值。 对于NIO,默认值为10000。对于APR/native,默认值为8192。仅对于NIO,将值设置为-1将禁用maxConnections功能,并且不计算连接数。(PS:一般不需要设置)
acceptCount:使用所有可能的请求处理线程时,传入连接请求的最大队列长度。 队列已满时收到的任何请求都将被拒绝。 默认值为100。
2.线程设置
<Connector port="8080" protocol="HTTP/1.1"
maxThreads="600"
acceptCount="300"
enableLookups="false"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8"/>
3.线程数设置建议
为了达到最优配置,我进行了通用业务系统登录及首页待办、查询、统计内容加载等场景的压力实测,建议:
在tomcat虚拟内存为2G,建议设置最大线程为500~600,可支持最大并发量为500~600
在tomcat虚拟内存为4G,建议设置最大线程为600~700,可支持最大并发量为600~700
如果需要达到自身业务系统的最优配置,还是需要根据自身业务系统的场景进行逐步压力实测,再根据结果进行线程数的上调或下调。
注意:另外,在另一篇文章“Tomcat性能调优:虚拟内存JVM设置”也提到“tomcat虚拟内存JVM最大设置为4G。经过实测4G以上性能提升极小,考虑nginx+tomcat集群做负载均衡。”
4.最佳线程数的获取
- 通过用户慢慢递增来进行性能压测,观察QPS,响应时间
- 根据公式计算:服务器端最佳线程数量=((线程等待时间+线程cpu时间)/线程cpu时间) * cpu数量
- 单用户压测,查看CPU的消耗,然后直接乘以百分比,再进行压测,一般这个值的附近应该就是最佳线程数量。
- 操作系统限制:Windows每个进程中的线程数不允许超过2000,Linux每个进程中的线程数不允许超过1000
猜你喜欢
- 2024-10-15 每个程序员应该彻底掌握的多线程编程(Linux C)
- 2024-10-15 线程池的使用场景和代码实现(线程池应用实例)
- 2024-10-15 Netty核心精讲之Reactor线程模型(netty 线程池模型讲解)
- 2024-10-15 浅谈Nginx服务器的内部核心架构设计
- 2024-10-15 java终极指南:你必须了解的提高Nginx服务器硬度的10个技巧
- 2024-10-15 三分钟了解PHP的进程和线程(三分钟了解php的进程和线程的区别)
- 2024-10-15 java面试之Nginx篇(javaweb nginx)
- 2024-10-15 linux服务器网络编程之线程模型(linux服务端多线程编程)
- 2024-10-06 关于nginx中进程的一些小常识(nginx的进程结构)
- 2024-10-06 一分钟快速部署Django应用(django用啥部署比较方便)
你 发表评论:
欢迎- 最近发表
-
- linux CentOS检查见后门程序的shell
- 网络安全工程师演示:黑客是如何使用Nmap网络扫描工具的?
- Linux中ftp服务修改默认21端口等(linux修改ftp配置文件)
- Linux系统下使用Iptables配置端口转发,运维实战收藏!
- 谈谈TCP和UDP源端口的确定(tcp和udp的端口号相同吗)
- Linux 系统 通过端口号找到对应的服务及相应安装位置
- 快速查找NAS未占用端口!Docker端口秒级排查+可视化占坑双杀技
- 【知识杂谈#2】如何查看Linux的(本地与公网)IP地址与SSH端口号
- 如何在Linux中查询 DNS 记录,这三个命令可谓是最常用、最经典的
- 【Linux系统编程】特殊进程之守护进程
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)