秒杀系统的性能优化

秒杀任务总体QPS预期是每秒几十万,对tomcat、redis、JVM参数进行优化。

tomcat线程数

4核8G的机器,一般就是开200-300个工作线程,这是个经验值。每秒一个线程处理3-5个请求,200多个线程的QPS可以达到1000左右。线程不能太多,太多的话就会导致cpu负载过高,请求处理不过来,增加接口的延迟响应。

JVM参数优化

JVM参数优化的核心在于尽量避免FGC,那么YGC次数肯定会变多,每次YGC时间大概几十毫秒的话,这个其实也没有太大的影响,基本接口还是在200毫秒左右。

-XX:SurvivorRatio=6

redis集群

redis一个分片大概可以扛2-3wQPS,8个分片大概是20w的QPS。此时的redis的cpu负载大概是在50%左右,尚可以支撑。

TPS与QPS

秒杀接口一次TPS会发生很多次redis的读写操作,所以会包含多次QPS查询。每秒几千的TPS就相当于几万甚至十几万的QPS。

生产环境压测数据:

TPS 4543

QPS 22w

累积访问量 175w

相关推荐
Cloud Traveler13 分钟前
JavaScript性能优化实战:从瓶颈分析到解决方案
开发语言·javascript·性能优化
编程在手天下我有9 小时前
缓存:缓解读库压力的高效方案与应用实践
数据库·缓存·性能优化·软件开发·系统设计·技术架构
在未来等你16 小时前
互联网大厂Java求职面试:高并发系统设计与架构实战
性能优化·消息队列·分布式事务·微服务架构·java面试·jvm内存模型·高并发系统设计
Frankabcdefgh17 小时前
使用Rust + WebAssembly提升前端渲染性能:从原理到落地
面试·性能优化·rust·webassembly·工程化
清源妙木真菌1 天前
高并发内存池
linux·性能优化·内存管理
eqwaak01 天前
基于DrissionPage的高效爬虫开发:以小说网站数据抓取为例
爬虫·python·语言模型·性能优化·交互·drissionpage
Ya-Jun1 天前
性能优化实践:渲染性能优化
android·flutter·ios·性能优化
计算机毕设定制辅导-无忧学长1 天前
ActiveMQ 性能优化与网络配置实战(一)
网络·性能优化·activemq
Attacking-Coder1 天前
前端面试宝典---性能优化
前端·性能优化
Ya-Jun2 天前
性能优化实践:性能监控体系
android·开发语言·flutter·ios·性能优化