GO性能优化的一些记录:trace工具的使用

使用场景:

1 想要查看接口延时性偏高

2 深入了解协程具体如何运营的详细信息(运行时长,或者什么原因导致了协程运行受阻)

可以使用 trace 功能,程序便会对下面的一系列事件进行详细记录,并且会依据所搜集到的这些信息,生成能够以可视化方式查看的 trace 视图

1 协程的创建过程、开始运行的时刻以及结束运行的时间点。

2 协程由于系统调用、通道操作、锁的使用等情况而出现被阻塞的现象。

3 网络 IO 相关的操作情况。

4 垃圾收集的相关活动情况。

Go 复制代码
import (
    "net/http"
    _ "net/http/pprof"
)

func main() {
    _ := http.ListenAndServe(":8000", nil)
    
}


执行:curl "http://localhost:8000/debug/pprof/trace?seconds=30" > trace.out

如果不能使用http等进行访问 我们可以在程序内部运行

Go 复制代码
import (
    "runtime/trace"
)

func main() {
    // 创建trace文件
    f, _ := os.Create("trace.out")
  
    defer f.Close()

    if err := trace.Start(f); err != nil {
        return
    }
    defer trace.Stop()

    // 执行
}

执行: go tool trace trace.out

1 分析协程阻塞情况

2 处理器是否得到充分使用

协程运行时间、同步阻塞时间、系统调用阻塞时间、调度延迟时间、查看处理器的使用状况、垃圾回收(GC)占比

相关推荐
blue_blooded9 分钟前
对College数据进行多模型预测(R语言)
开发语言·r语言
越来越无动于衷16 分钟前
企业信息管理系统开发实战:基于 Spring Boot+MyBatis+Thymeleaf
spring boot·后端·mybatis
努力的小帅20 分钟前
C++_红黑树树
开发语言·数据结构·c++·学习·算法·红黑树
CN-Dust21 分钟前
【C++】指针
开发语言·c++
调试人生的显微镜22 分钟前
移动端WebView调试实战 全面排查渲染性能与布局跳动问题
后端
hweiyu0024 分钟前
学习Scala语言的最佳实践有哪些?
开发语言·学习·scala
轻语呢喃29 分钟前
JavaScript数据检索:从顺序到哈希的效率跃迁
javascript·后端
小杰来搬砖34 分钟前
讲解缓存穿透、缓存击穿、缓存雪崩
后端
许野平39 分钟前
Rust:anyhow::Result 与其他 Result 类型转换
服务器·开发语言·rust·result·anyhow
该用户已不存在42 分钟前
2025 年,Python工具别只知道Pycharm了
前端·后端·python