Files
weiyu/jmeter/readme.md

273 lines
5.5 KiB
Markdown
Raw Normal View History

2025-07-31 20:06:45 +08:00
# 微语登录性能测试
2024-12-24 15:09:06 +08:00
2025-07-31 20:06:45 +08:00
本目录包含用于测试微语系统登录功能的JMeter测试脚本。
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
## 文件说明
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
- `01_login.jmx` - JMeter测试计划文件包含多种登录方式的测试
- `users.csv` - 测试用户数据文件
- `run_login_test.sh` - 测试执行脚本
- `README.md` - 本说明文件
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
## 测试覆盖范围
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
### 1. 获取验证码测试
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- **接口**: `GET /kaptcha/api/v1/get`
- **并发用户**: 100
- **加压时间**: 10秒
- **测试目的**: 验证验证码生成服务的性能
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
### 2. 用户名密码登录测试
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- **接口**: `POST /auth/v1/login`
- **并发用户**: 500
- **加压时间**: 30秒
- **持续时间**: 10分钟
- **测试目的**: 测试传统用户名密码登录的性能
### 3. 手机验证码登录测试
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- **发送验证码接口**: `POST /auth/v1/send/mobile`
- **登录接口**: `POST /auth/v1/login/mobile`
- **并发用户**: 200
- **加压时间**: 20秒
- **持续时间**: 5分钟
- **测试目的**: 测试手机验证码登录流程的性能
### 4. 邮箱验证码登录测试
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- **发送验证码接口**: `POST /auth/v1/send/email`
- **登录接口**: `POST /auth/v1/login/email`
- **并发用户**: 100
- **加压时间**: 10秒
- **持续时间**: 5分钟
- **测试目的**: 测试邮箱验证码登录流程的性能
### 5. AccessToken登录测试
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- **接口**: `POST /auth/v1/login/accessToken`
- **并发用户**: 300
- **加压时间**: 15秒
- **持续时间**: 5分钟
- **测试目的**: 测试Token验证登录的性能
## 环境要求
### 软件要求
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- Apache JMeter 5.5+
- Java 8+
- Bash shell (用于执行脚本)
### 系统要求
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- 内存: 至少4GB可用内存
- 磁盘: 至少1GB可用空间用于存储测试结果
- 网络: 稳定的网络连接到测试目标服务器
## 安装和配置
### 1. 安装JMeter
#### Linux/macOS
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```bash
# 下载JMeter
wget https://downloads.apache.org/jmeter/binaries/apache-jmeter-5.5.tgz
# 解压
tar -xzf apache-jmeter-5.5.tgz
# 移动到合适位置
sudo mv apache-jmeter-5.5 /usr/local/
```
#### Windows
2025-07-31 20:06:45 +08:00
1. 下载JMeter: <https://jmeter.apache.org/download_jmeter.cgi>
2025-07-31 20:01:44 +08:00
2. 解压到合适目录
3. 将bin目录添加到PATH环境变量
### 2. 配置测试环境
#### 修改测试目标地址
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
编辑 `01_login.jmx` 文件中的用户定义变量:
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```xml
<elementProp name="host" elementType="Argument">
<stringProp name="Argument.name">host</stringProp>
<stringProp name="Argument.value">your-server-host</stringProp>
</elementProp>
<elementProp name="port" elementType="Argument">
<stringProp name="Argument.name">port</stringProp>
<stringProp name="Argument.value">9003</stringProp>
</elementProp>
```
#### 准备测试数据
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
确保 `users.csv` 文件包含有效的测试用户数据:
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```csv
username,password,email,mobile
testuser1,password123,testuser1@example.com,13800138001
...
```
## 执行测试
### 方法1: 使用脚本执行(推荐)
```bash
# 使用默认JMeter路径
./run_login_test.sh
# 指定JMeter路径
./run_login_test.sh /path/to/jmeter/bin
```
### 方法2: 直接使用JMeter命令
```bash
# 进入jmeter目录
cd jmeter
# 执行测试
jmeter -n -t 01_login.jmx -l results/test_result.jtl -e -o reports/test_report
```
### 方法3: 使用JMeter GUI
1. 启动JMeter GUI
2025-07-31 20:06:45 +08:00
2024-12-24 17:11:04 +08:00
```bash
2025-07-31 20:01:44 +08:00
jmeter
```
2. 打开测试计划文件 `01_login.jmx`
3. 点击运行按钮开始测试
## 测试结果分析
### 结果文件
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- `results/` - 原始测试结果文件(.jtl)
- `reports/` - HTML格式的测试报告
### 关键指标
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- **响应时间**: 平均响应时间、90/95/99百分位响应时间
- **吞吐量**: 每秒处理的请求数(TPS)
- **错误率**: 请求失败的比例
- **并发用户数**: 系统能够支持的最大并发用户数
### 性能基准
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
根据测试计划文档,建议的性能基准:
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- 登录响应时间 < 2秒
- 错误率 < 1%
- 支持500并发用户登录
## 故障排除
### 常见问题
#### 1. JMeter找不到
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```
错误: 找不到JMeter可执行文件
```
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
**解决方案**: 确保JMeter已正确安装或通过参数指定正确的路径
#### 2. 测试数据文件不存在
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```
错误: 找不到测试数据文件: users.csv
2024-12-24 17:11:04 +08:00
```
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
**解决方案**: 确保 `users.csv` 文件存在于当前目录
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
#### 3. 网络连接失败
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```
错误: 连接被拒绝
```
2025-07-31 20:06:45 +08:00
**解决方案**:
2025-07-31 20:01:44 +08:00
- 检查目标服务器是否运行
- 验证端口配置是否正确
- 检查防火墙设置
#### 4. 验证码错误
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```
错误: 验证码验证失败
```
2025-07-31 20:06:45 +08:00
**解决方案**:
2025-07-31 20:01:44 +08:00
- 检查验证码接口是否正常工作
- 确认验证码缓存服务配置正确
### 调试技巧
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
1. **启用详细日志**
2025-07-31 20:06:45 +08:00
2024-12-24 17:11:04 +08:00
```bash
2025-07-31 20:01:44 +08:00
jmeter -n -t 01_login.jmx -l results/test_result.jtl -e -o reports/test_report -L DEBUG
2024-12-24 17:11:04 +08:00
```
2025-07-31 20:01:44 +08:00
2. **查看JMeter日志**
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```bash
tail -f jmeter.log
```
3. **使用JMeter GUI调试**
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- 在GUI模式下运行单个请求
- 查看请求和响应详情
## 扩展和定制
### 添加新的登录方式
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
1. 在测试计划中添加新的线程组
2. 配置相应的HTTP请求
3. 添加必要的断言和提取器
### 修改测试参数
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
- 调整并发用户数
- 修改加压时间
- 更改测试持续时间
### 集成到CI/CD
2025-07-31 20:06:45 +08:00
2025-07-31 20:01:44 +08:00
```bash
# 在CI/CD流水线中执行测试
./run_login_test.sh
# 检查测试结果
if [ $? -eq 0 ]; then
echo "性能测试通过"
else
echo "性能测试失败"
exit 1
fi
```
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
## 联系和支持
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
如有问题或建议请联系开发团队或提交Issue。
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
## 更新日志
2024-12-24 17:11:04 +08:00
2025-07-31 20:01:44 +08:00
- v1.0 - 初始版本,支持基本登录功能测试
- 支持用户名密码、手机验证码、邮箱验证码、AccessToken四种登录方式
- 包含完整的测试数据准备和结果分析