OpenResty 从入门到实战
温铭
OpenResty 软件基金会第一任主席,Apache APISIX 项目 VP
20903 人已学习
新⼈⾸单¥59
登录后,你可以任选4讲全文学习
课程目录
已完结/共 52 讲
结束语 (1讲)
OpenResty 从入门到实战
15
15
1.0x
00:00/00:00
登录|注册

29 | 最容易失准的性能测试?你需要压测工具界的“悍马”wrk

检测服务端程序是否正常运行
使用自动化工具 c1000k
Nginx 配置
进程限制
最大打开文件数
关闭 SELinux
wrk
ab
发送请求
压测前检查
测试环境
性能测试工具
性能测试

该思维导图由 AI 生成,仅供参考

你好,我是温铭。
在测试章节的最后一节课,我和你来聊聊性能测试。这部分内容并非 OpenResty 独有,对于其他的后端服务来说,都是一样适用的。
性能测试很常见,在我们交付产品的时候,都会带有性能指标的要求,比如 QPS、TPS 达到多少,延时要低于多少毫秒,可以并发支持多少用户的连接等等。对于开源项目而言,我们发版本之前也会做一次性能测试,和上一个版本对比,看是否有明显的衰退。也有一些中立的网站,会发布同类产品的性能对比数据。不得不说,性能测试离我们真的很近。
在我的十几年的工作中,针对不同的产品做过很多次性能测试,中间也踩过不少坑。后来,我逐渐地发现,性能测试做起来简单,但做对却并不容易,甚至可以说,很多性能测试的结果都是失准的。
那么,如何做一个科学严谨的性能测试呢?今天这节课,且听我娓娓道来。

性能测试工具

工欲善其事,必先利其器。选择一个趁手的性能测试工具,是成功的一半。
ab 这个 Apache Benchmark 工具你应该很熟悉,可以说是最简单的性能测试工具,但可惜的是并不好用。这是因为,当前服务端基本都基于协程和异步 I/O 来开发,性能不差;而 ab 利用不到机器的多核,生成的请求压力不够大。这种情况下,ab 测试得到的结果,并不真实,反而变成了 ab 自身的性能测试。
确认放弃笔记?
放弃后所记笔记将不保留。
新功能上线,你的历史笔记已初始化为私密笔记,是否一键批量公开?
批量公开的笔记不会为你同步至部落
公开
同步至部落
取消
完成
0/2000
荧光笔
直线
曲线
笔记
复制
AI
  • 深入了解
  • 翻译
    • 英语
    • 中文简体
    • 中文繁体
    • 法语
    • 德语
    • 日语
    • 韩语
    • 俄语
    • 西班牙语
    • 阿拉伯语
  • 解释
  • 总结

本文介绍了性能测试的重要性以及如何选择和使用性能测试工具。作者推荐了一款强大的压测工具wrk,并详细介绍了测试环境的准备工作,包括关闭SELinux、调整最大打开文件数、进程限制和Nginx配置。在进行压测前的检查工作方面,作者提到了使用自动化工具c1000k和检测服务端程序是否正常运行。文章还强调了压测时间的重要性,以及在压测期间使用监控工具来确认服务端目标程序是否跑满CPU。最后,作者提到了wrk的统计结果,包括QPS和延时,以及对延时分布数据的注意事项。整体而言,本文为读者提供了一份科学严谨的性能测试指南,帮助他们更好地进行性能测试工作。

仅可试看部分内容,如需阅读全部内容,请付费购买文章所属专栏
《OpenResty 从入门到实战》
新⼈⾸单¥59
立即购买
登录 后留言

全部留言(8)

  • 最新
  • 精选
  • 老王
    我怎么记得春哥在 google group 里多次提到 ab 是当前最佳测试工具呢

    作者回复: 你应该记错了吧?或者是他遇到 wrk 之前的看法

    2019-07-31
    1
  • 土老鳖
    老师您好,如果我想调试ngx源码,比如测试内存池,或者ngx自己实现的list,甚至是配置文件解析流程。有什么好的办法能让我做加桩测试吗?或者有其他好的建议吗?

    作者回复: NGINX 官方提供了调试的方法:https://docs.nginx.com/nginx/admin-guide/monitoring/debugging/

    2019-08-06
  • helloworld
    老师,从redis读取数据和向redis写数据,是阻塞操作吗

    作者回复: 使用 lua-resty-redis 库来操作的话,就不是阻塞操作,因为底层使用的是 cosocket

    2019-07-31
  • 许童童
    老师你好,局域网内带宽有限,测不到QPS最大值怎么办?

    作者回复: 可以用交换机自己组建一个网络,里面只有测试服务器

    2019-07-31
  • 许童童
    老师你好, net.ipv4.ip_conntrack_max = 1020000 net.ipv4.netfilter.ip_conntrack_max = 1020000 这两个在centos下配置会报错,是什么原因呢?

    作者回复: 具体什么报错呢?centos 什么版本?

    2019-07-31
    4
  • Charles
    请教温老师,跑wrk的客户端是放在外网上的机器,还是和服务端同一局域网内的机器,哪个更有性能测试意义?谢谢

    作者回复: 最好在局域网,排除网络的干扰因素。

    2019-07-31
    3
  • 言十年
    wrk.method="PUT" function request() local num = math.random(1,99999999) local num1 = math.random(1,99999999) local num2 = math.random(1,99999999) local path = "/v3/333333/" .. num .. "dfadnl" ..num1.."sssssdf" .. num2 .. ".jpg"; headers = {authorization= "xxxxxx"} local content = load_file("/home/www/1M.csv") return wrk.format("PUT", path, headers, content) end local open = io.open local insert = table.insert local concat = table.concat function load_file(filename) local file = open(filename, 'rb') if not file then return end local f = {} for line in file:lines("l") do insert(f, line) end file:close() return concat(f, '\n') end
    2020-10-01
    1
  • 冰漪
    执行后会有socket errors,这个error影响查看数据结果吗,如何避免这种error呢,所有的配置已经按照文章内容改过了 wrk -t8 -c200 -d40s http:``//www.baidu.com Running 40s test @ http://www.baidu.com 8 threads and 200 connections Thread Stats Avg Stdev Max +/- Stdev Latency 291.89ms 314.10ms 1.99s 87.63% Req/Sec 97.84 39.19 247.00 69.10% 30817 requests in 40.10s, 308.44MB read Socket errors: connect 0, read 426, write 0, timeout 219 Requests/sec: 768.47 Transfer/sec: 7.69MB
    2023-11-15归属地:江苏
收起评论
显示
设置
留言
8
收藏
沉浸
阅读
分享
手机端
快捷键
回顶部