Jmeter 性能压测-Tomcat连接数

1、影响性能线程状态

①BLOCKED,如果线程中有BLOCKED,就代表有阻塞情况,需要进行排查

②TIMED_WAITING,如果线程中有TIMED_WAITING,就代表有等待的情况,要分情况来排查

  1. 系统线程在等待(如果以java.*,并且线程快照信息比较短,可以忽略)

  2. 业务线程在等待(如果以com.*,cn.*,org.*,线程快照信息比较长,需要重点关注)

2、数据库连接池

项目启动时,会提前创建N个数据库链接,然后存放到连接池中。

如果需要执行SQL的时候,可以直接从连接池中拿到一个链接使用,使用完毕后,再放回连接池中。

3、如何确定连接池中的连接数不足?

①线程快照,大量业务线程正在等待获取链接

②查看连接池配置,确定最大允许的连接数是多少,然后监控数据库当前连接数,判断是否达到上限

4、如何查看服务器链接数?

  1. yum install -y net-tools

  2. nestat -anp | grep 3306

  3. netstat -anp | grep 172.21.0.16:3306 | grep 14963 | wc -l

5、如何配置连接池参数?

初始连接数:1-10

最小连接数:和初始值保持一致

最大连接数:几十个,通常50个够用,不建议超过100

6、查看数据库本身的连接数

最大连接数:

show variables like '%connection%';

MySQL默认最大连接数是150,修改/etc/my.cnf

当前连接数:

netstat -anp |grep 172.21.0.16:3306 | wc -l

7、Tomcat连接数

在端口号处添加:

  1. maxConnection="15000"

  2. acceptCount="200"

maxConnection默认值10000,acceptCount默认值100,最大支持的连接数=10100

8、Redis连接数

默认最大连接数:maxClient=10000

9、Nginx连接数

最大连接数=worker的数量(CPU的核数)* 每个worker支持的最大连接数(默认1024)

相关推荐
TravisBytes4 分钟前
Redis 发布/订阅模式与消息队列
java·linux·c++·redis·缓存·bootstrap
懒鸟一枚37 分钟前
详解Maven的setting配置文件中mirror和repository的区别
java·maven
QQ_5388769141 分钟前
Z240004基于Java+ssm+maven+mysql的房屋租赁系统的设计与实现
java·mysql·spring·maven
shaoweijava1 小时前
私人诊所管理系统(源码+数据库+报告)
java·开发语言·数据库·spring boot·mysql·mybatis
知识分享小能手1 小时前
Java学习教程,从入门到精通,Java Stack(堆栈)语法知识点及语法知识点(58)
java·大数据·开发语言·学习·intellij-idea·java后端·java开发
瑞金彭于晏1 小时前
yml和xml分别代表什么
xml·java·mybatis
YAy171 小时前
FastJson反序列化学习-01
java·开发语言·安全·web安全·网络安全
MatthewMao1 小时前
设计模式11:单例模式(全局唯一)
java·单例模式·设计模式
123yhy传奇2 小时前
【学习总结|DAY018】Java异常、泛型、集合框架
java·开发语言
Java学长-kirito2 小时前
springboot/ssm武理多媒体信息共享平台Java代码编写web项目视频作品分享源码
java·spring boot·后端