0

0

Golang并发编程如何做压力测试_Go语言性能测试方法

P粉602998670

P粉602998670

发布时间:2026-01-13 12:23:01

|

577人浏览过

|

来源于php中文网

原创

Go并发压力测试核心是控制goroutine生命周期、资源竞争与真实负载模型;盲目增并发会掩盖瓶颈、扭曲pprof数据;-bench适合无状态逻辑,需加-benchmem看内存分配,禁用time.Sleep,I/O场景应换专用压测工具。

golang并发编程如何做压力测试_go语言性能测试方法

Go 并发程序的压力测试,核心不是“起多少 goroutine”,而是控制好 goroutine 生命周期、资源竞争点和真实负载模型。盲目增加并发数只会掩盖瓶颈,甚至让 pprof 数据失真。

go test -bench 测纯函数并发吞吐,但别信默认结果

基准测试适合验证无状态逻辑(比如加解密、编解码),但默认 Benchmark 不模拟真实请求节奏,容易高估吞吐:

  • -benchmem 必加,看每次操作分配了多少内存,Allocs/op 高往往意味着 GC 压力大
  • 避免在 Benchmark 函数里写 time.Sleep 模拟延迟——它会阻塞整个 B.N 循环,扭曲 ns/op
  • 若被测函数含 I/O(如 HTTP 调用、DB 查询),go test -bench 无法反映连接池、超时、重试等行为,应改用专用压测工具
func BenchmarkConcurrentParseJSON(b *testing.B) {
	b.ReportAllocs()
	b.RunParallel(func(pb *testing.PB) {
		for pb.Next() {
			_ = json.Unmarshal([]byte(`{"id":1}`), &struct{ ID int }{})
		}
	})
}

HTTP 服务压测:用 heyvegeta,别手写 goroutine 循环

自己用 for i := 0; i 发请求,既难控 QPS,又无法统计成功率、P95 延迟、连接复用效果。推荐:

  • hey -n 10000 -c 100 -m POST -d '{"x":1}' http://localhost:8080/api:轻量、输出直观,支持基本认证和 header
  • vegeta attack -targets=targets.txt -rate=200 -duration=30s | vegeta report:可定义复杂请求流(如阶梯增压)、支持 TLS 和自定义 body
  • 注意设置 http.TransportMaxIdleConnsMaxIdleConnsPerHost,否则压测客户端自身会因连接耗尽而失败

查并发瓶颈:pprof 要抓对时间点,且必须看 goroutinemutex profile

服务在压测中变慢,光看 cpu profile 可能找不到根因:

绘蛙-多图成片
绘蛙-多图成片

绘蛙新推出的AI图生视频工具

下载

立即学习go语言免费学习笔记(深入)”;

  • curl "http://localhost:6060/debug/pprof/goroutine?debug=2":看是否大量 goroutine 卡在 selectchan receivenet/http.(*conn).serve —— 这说明处理逻辑阻塞或 channel 容量不足
  • curl "http://localhost:6060/debug/pprof/mutex?debug=1":若 contention 高,说明锁争用严重;配合 go tool pprof 查具体锁位置
  • 启动服务时加 -gcflags="-l" 禁用内联,能让 pprof 显示更准确的调用

真实场景必须模拟业务约束:超时、重试、限流、连接池

压测结果脱离这些,等于没测:

  • HTTP client 必须设 Timeout,否则一个慢请求拖垮整个 goroutine 池
  • 数据库连接池(如 sql.DB.SetMaxOpenConns)要与压测并发数匹配;过小会排队,过大则 DB 扛不住
  • golang.org/x/time/rate.Limiter 在入口限流,观察下游组件(Redis、MySQL)在不同 QPS 下的响应曲线
  • 压测持续时间至少 2–3 分钟,短于 30 秒的结果受 GC 周期、JIT(如果启用了)干扰太大

最常被忽略的一点:压测环境的 GOMAXPROCS 和生产是否一致?容器中未显式设置时,Go 1.21+ 会按 cgroup CPU quota 自动调整,但旧版本或非容器环境可能仍为全核数,导致线程调度行为差异极大。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

178

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

337

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

388

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

189

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

192

2025.06.17

PHP 表单处理与文件上传安全实战
PHP 表单处理与文件上传安全实战

本专题聚焦 PHP 在表单处理与文件上传场景中的实战与安全问题,系统讲解表单数据获取与校验、XSS 与 CSRF 防护、文件类型与大小限制、上传目录安全配置、恶意文件识别以及常见安全漏洞的防范策略。通过贴近真实业务的案例,帮助学习者掌握 安全、规范地处理用户输入与文件上传的完整开发流程。

5

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 787人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号