AB压力测试运维工程师技术教程

你现在执行了ab -n 1000 http://cxk666.com/命令,终端只显示了测试开始和“执行完毕”的提示,但没有输出具体的性能测试结果,需要先明确结果缺失的原因,再补充指令获取完整报告,同时结合场景优化测试参数。

一、为什么没有显示具体结果?

出现这种情况通常有两个常见原因:

  1. 结果被重定向/终端输出限制:部分系统环境下,ab的输出可能会被默认重定向,或终端缓冲区限制导致结果未显示。
  2. 测试过程中出现隐性错误:比如目标地址无法访问、响应异常,但ab未明确提示(如返回403/500等状态码时,部分版本的ab会只显示执行完毕,不输出详细结果)。

二、解决方案:获取完整测试结果

方案1:强制输出结果(解决终端显示问题)

直接将结果重定向到文件,或强制输出到终端,命令如下:

# 方式1:将结果保存到文件,再查看文件(推荐,方便后续分析)
ab -n 1000 http://cxk666.com/ > ab_test_result.txt 2>&1
# 查看文件内容
cat ab_test_result.txt

# 方式2:强制输出到终端(排除重定向问题)
ab -n 1000 http://cxk666.com/ 2>&1

解释2>&1是将标准错误(如错误提示)和标准输出(测试结果)合并输出,避免结果被隐藏。

方案2:添加并发数+长连接,优化测试(贴近真实场景)

你只指定了总请求数-n 1000,没有指定并发数-c,ab默认是单并发测试,这种测试结果参考意义不大。建议补充并发数和长连接参数,命令如下:

# 模拟50个并发用户,总共发送1000个请求,开启长连接(更贴近真实访问)
ab -c 50 -n 1000 -k http://cxk666.com/ > ab_test_result.txt 2>&1
# 查看结果
cat ab_test_result.txt

参数解释

  • -c 50:50个并发用户,模拟多用户同时访问。
  • -k:开启HTTP Keep-Alive长连接,一个TCP连接处理多个HTTP请求,符合浏览器的访问习惯。
方案3:排查目标地址的访问问题(针对隐性错误)

如果上述命令仍无结果,先验证目标地址是否能正常访问:

# 测试目标地址的响应状态
curl -I http://cxk666.com/

如果返回403 Forbidden(和你之前的问题一致),说明ab的请求被Nginx拦截,此时需要:

  1. 用回环地址测试:ab -c 50 -n 1000 -k http://127.0.0.1/ > ab_test_result.txt 2>&1
  2. 或修改Nginx配置,允许当前服务器IP访问(参考之前的解决方案)。

三、ab测试结果核心指标解读(获取结果后)

当你看到完整结果后,重点关注以下关键指标:

指标含义参考意义
Requests per secondQPS(每秒处理的请求数)核心性能指标,数值越高越好
Time per request(平均值)单个请求的平均响应时间(毫秒)数值越低,接口响应越快
Time per request(并发平均值)并发场景下,每个请求的实际等待+处理时间反映并发压力下的响应性能
Failed requests失败的请求数正常情况下应为0,非0表示接口有异常

总结

  1. 获取结果:使用> ab_test_result.txt 2>&1将ab测试结果保存到文件,或用2>&1强制输出到终端,解决结果缺失问题。
  2. 优化测试:添加-c(并发数)和-k(长连接)参数,让测试结果更贴近真实业务场景。
  3. 排查问题:若目标地址返回403,改用127.0.0.1测试,或修改Nginx的访问控制配置。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

teayear

读后有收获可以获取更多资源

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值