当前位置: 首页 > news >正文

电商项目_秒杀_压测

电商项目_秒杀_架构及核心-CSDN博客

本文的作用:学习秒杀场景下压测计划,具体执行暂未执行。

压测内容

根据秒杀活动的业务图, 分析需要压测的接口:

1. 秒杀商品详情页

  • 商品静态信息
  • 动态判断:是否可以点击下单:库存量、是否预约

2. 结算页(确定下单接口)【暂未压测这个】

  • 静态信息
  • 验证码

3. 提交订单接口

        在这⾥后端订单服务通过MQ异步完成数据库中库存的扣减和订单的⽣成

压测步骤

1. 商品详情页

1.1 基准压测

秒杀系统redis缓存

主从节点做压测,先修改重要配置项

# ⽇志备份采⽤appendonly

appendonly yes

# ⽇志刷盘设置为每秒刷盘 --有些压测环境会配置为不刷盘,这样可以提升压测性能

appendfsync everysec

压测脚本

-- 主节点

-- 库存扣减,需要读写主节点, 压测主节点

-- 100并发(订单服务扣减库存)   20W的get set操作  测试的字节大小设置为8个字节

/usr/local/redis-6.2.7/src/redis-benchmark -c 100 -n 200000 -t get,set -d 8

-- 从节点

-- 从节点主要负责同步秒杀库存数据。其作⽤主要是供 OpenResty 读取库存⽤,⽽OpenResty 我们配置的是开启7 个⼯作进程,加上主进程,⼀共是 8 个进程(OpenResty 读取库存)。

# /usr/local/redis-6.2.7/src/redis-benchmark -c 8 -n 200000 -t get -d 8

秒杀系统Nginx静态网页

品详情⻚处理是分为两个步骤,

  1. ⾸先在秒杀开始时,通过 Freemark ⽣成商品对应的静态详情⻚,放到 OpenResty 当中。
  2. 然后秒杀过程中,客户每次访问详情⻚,都会在 OpenResty 中直接通过lua脚本访问 Redis,实时获取商品库存。

尝试访问⼀个秒杀商品的详情⻚:http://192.168.65.28/seckill_3_29.html 。使⽤ab,模拟 200 个线程发送 30000 个请求。(这个页面去掉了redis获取库存的逻辑,只是个静态页面)

-- 200个线程  30000个请求

[root@192-168-65-190 src]# ab -c 200 -n 30000 http://192.168.65.28/seckill_3_29.html

1.2 秒杀业务压测

秒杀商品详情页

在Nginx静态网页的基础上,增加了lua脚本访问redis获取库存的逻辑。

[root@192-168-65-190 src]# ab -c 200 -n 100000 http://192.168.65.28/product?

flashPromotionId=3\&promotionProductId=29\&memberId=462245

2. 秒杀下单接口

该接⼝整体的业务逻辑分为两个部分,

  1. ⾸先是从缓存中进⾏库存扣减,
  2. 然后异步发送消息到 MQ,完成下单操作。

在压测时,针对两个部分分别进⾏测试。

2.1 基准压测

MQ生产者基准测试,只需要将消息发送的RocketMq即可。

-- 使用rocketmq提供的压测benchmark的方式进行压测

[root@192-168-65-164 benchmark]# pwd

/app/rocketmq/rocketmq-all-4.9.5-bin-release/benchmark

[root@192-168-65-164 benchmark]# ./producer.sh -n rocketmq1:9876

如果性能比较低,可能是给rocketMq分配的内存不够,或者部署rocketmq的服务器还有其他的服务在跑。 

2.2 秒杀业务压测

[root@192-168-65-190 ~]# ab -c 1000 -n 10000 -p "params" -T "application/json" -H

"Content-Type: application/json" -H "memberId: 1"

"http://192.168.65.133:9922/seckillOrder/generateOrder"

http://www.dtcms.com/a/294642.html

相关文章:

  • 策略模式(Strategy Pattern)+ 模板方法模式(Template Method Pattern)的组合使用
  • 水泥厂码垛环节的协议转换实践:从Modbus TCP到DeviceNet
  • opencv学习(图像读取)
  • CPU,减少晶体管翻转次数的编码
  • haproxy算法
  • LSTM学习笔记
  • unity小:webgl开发注意事项(持续更新)
  • 2025年7月Nature子刊-Adam梯度下降优化算法Adam Gradient Descent-附Matlab免费代码
  • CVE-2025-32463漏洞:sudo权限提升漏洞全解析
  • OpenLayers 快速入门(五)Controls 对象
  • 西安旅游行业从业者:凤凰新闻怎么发稿有哪些注意事项
  • 编程日常开发工具整理
  • 智能工具重塑光伏设计:精准、高效与科学的融合
  • 第二章 W55MH32 DHCP示例
  • 安卓项目--基于百度云的人脸识别考勤系统
  • 基于沁恒微电子CH32V307单片机使用
  • 前端项目下载发票pdf文件要求改文件名笔记
  • LLM指纹底层技术——模型压缩与优化
  • Windows安装git教程(图文版)
  • 批量剪辑矩阵分发系统源码搭建,支持OEM
  • 电机驱动-理论学习-FOC算法理解
  • [硬件电路-73]:模拟器件 - 什么是电路的信号振铃现象?其根本原因?如何解决?
  • 逆向入门(41)程序逆向篇-crackme
  • Rocky9.4部署Zabbix7
  • WebGIS 中常用公共插件
  • 星座占卜信息分享静态网站项目练习!
  • 【大模型文生图、文生音频实战Demo】基于Spring AI Alibaba和阿里百炼大模型实现文生图、文生视频
  • LeetCode 407:接雨水 II
  • 网络编程初识(详细易懂)
  • [强网杯 2019]高明的黑客