当前位置: 首页 > news >正文

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

使用场景:

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

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

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

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

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

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

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

import ("net/http"_ "net/http/pprof"
)func main() {_ := http.ListenAndServe(":8000", nil)}执行:curl "http://localhost:8000/debug/pprof/trace?seconds=30" > trace.out

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

 

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)占比

 

 

http://www.lryc.cn/news/512632.html

相关文章:

  • dede-cms关于shell漏洞
  • NAT 技术如何解决 IP 地址短缺问题?
  • 使用 IDE生成 Java Doc
  • 通过无障碍服务(AccessibilityService)实现Android设备全局水印显示
  • flask后端开发(2):URL与视图
  • 力扣-数据结构-7【算法学习day.78】
  • 【潜意识Java】Java中深入解析抽象类与接口的差异的完整笔记总结【保姆级详细教程】
  • 【Flink运行时架构】系统构架
  • uni-ui样式修改
  • 【linux板卡】lubancat通过vnc远程访问桌面
  • SQLiteDataBase数据库
  • STM32 高级 物联网通讯之蓝牙通讯
  • react中实现拖拽排序
  • 【华为OD-E卷-AI处理器组合100分(python、java、c++、js、c)】
  • 语音识别基础算法——动态时间规整算法
  • 模型工作流:自动化的模型内部三角面剔除
  • 解读一个新建的 Spring Boot 项目
  • Vue多页面路由与模版解析
  • Python爬虫(二)- Requests 高级使用教程
  • 并联带阻滤波器带通滤波器对幅值和相位的影响(IIR)
  • 攻防世界web新手第五题supersqli
  • vue3学习笔记(10)-$subscribe,store组合式写法
  • 操作系统论文导读(八):Schedulability analysis of sporadic tasks with multiple criticality specifications——具有多个
  • 计算机网络与通信复习
  • 【Scala】图书项目系统代码演练3.1/BookService
  • 人工智能基础软件-Jupyter Notebook
  • C++ 设计模式:模板方法(Template Method)
  • GDPU Vue前端框架开发 跨年大礼包
  • 搭建一个高效且安全的APP分发平台
  • Leetcode打卡:二叉树中的链表