先说下 ThreadPoolExecutor 的基本原理:1. 当提交一个任务时,如果线程数没有达到coreSize,那么就会新建一个线程,并绑定该任务,直到数量到达coreSize前都不会重用之前的线程2.到达后,提交的任务都会放到一个等待队列中进行等待,线程池中的线程会使用take()阻塞的从等 ...
分类:
其他好文 时间:
2020-04-07 15:45:58
阅读次数:
56
需求1:有一个项目,500用户同时登录,响应时间能达到多少; 需求2:考勤打卡,最大吞吐量能达到多少(每秒最大能完成多少笔打卡业务); 需求3:银行业务,如果需要支持1分钟内完成3000笔取款操作,平均每秒能支持多少用户同时取款完成; 答1:线程组设置线程数500,循环1次,并设置集合点为500;查 ...
分类:
其他好文 时间:
2020-04-05 23:53:13
阅读次数:
103
集合点的目的 1、让各个线程(用户)步调一致,对系统进行加压 2、达到模拟真实并发访问的效果 例如:进行签到,要求五分钟内进行签到完毕,此时可以用集合点来完成 创建集合点 Number of Simulated Users to Group by:集合多少人后再执行请求(也就是执行的线程数)注意:等 ...
分类:
其他好文 时间:
2020-04-05 20:32:23
阅读次数:
66
我前段时间的一篇博客 "java网络编程——多线程数据收发并行" 总结了服务端与客户端之间的收发并行实践。原理很简单,就是针对单一客户端,服务端起两个线程分别负责read和write操作,然后线程保持阻塞等待读写执行。 事实上,这样的模式非常糟糕。因为每一个客户端在服务端需要占用两条线程,假如有10 ...
分类:
编程语言 时间:
2020-04-04 21:11:59
阅读次数:
131
get、post请求方式在jmeter中使用步骤 一、jmeter工具测试接口时使用步骤: 1、测试计划右键--添加--Threads(Users)--线程组(线程数就是并发数) 2、线程组右键--Sampler--HTTP请求--填写域名或IP、端口默认80,选择请求方式get,输入接口url域名 ...
分类:
其他好文 时间:
2020-04-04 11:15:40
阅读次数:
73
线程池 2.1 线程池思想概述 我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间。 那么有没有一种办法使得线程可以复用,就 ...
分类:
编程语言 时间:
2020-04-03 23:47:43
阅读次数:
87
问题: dubbo线程池耗尽,活跃线程数超过线程池最大线程数(dubbo默认线程池最大线程数为200) 登录服务提供者所在服务器 通过命令行连接dubbo: //telnet 服务提供者ip dubbo端口 telnet 20.1.16.26 20881 查看dubbo活跃线程: status -l ...
分类:
编程语言 时间:
2020-04-03 12:02:43
阅读次数:
240
在jmeter中,提到m并发,你可能马上想到线程数设置为m; 调节服务器压力的是rps,即每秒请求数;rps由线程数,循环次数,ramp-up time调节; 问题: 有一个页面,需要测试一下最大支持多少用户并发? 此时需计算的是最大用户并发数,强调的是同时操作,也可以理解为同时发起请求; 针对这个 ...
分类:
Web程序 时间:
2020-03-31 19:11:16
阅读次数:
1017
一、微服务架构中的熔断 1.1 前言 我们知道,如果一个软件系统的并发请求数目超过了系统的最佳线程数,那么就会导致激烈的资源竞争,随着资源的匮乏甚至枯竭,整个系统也就面临着灾难。 所以,很多软件系统为了保证即使在出现并发用户数 最佳线程数时,也不至于导致整个万网站崩溃,都会采用一些技术手段来避免发生 ...
分类:
其他好文 时间:
2020-03-30 16:34:37
阅读次数:
77
将/etc/fstab 文件中包含swap的行注释掉 单用户可以打开的最大文件数量,可以设置为官方推荐的65536或更大些 单用户线程数调大 单进程可以使用的最大map内存区域数量 参数修改立即生效 ...
分类:
系统相关 时间:
2020-03-28 13:33:58
阅读次数:
268