Go诊断工具

        Go 提供了一些出色的诊断工具,可帮助我们深入了解应用程序的执行情况。

1. 分析工具

        分析工具可观测应用程序执行的各种指标。它使我们能够解决性能问题、检测争用、定位内存泄漏等。这些指标可以通过以下几个配置文件收集:

  • CPU--确定应用程序将时间花在了哪里
  • Goroutine--报告正在进行的 goroutine 的栈跟踪
  • Heap--报告堆内存分配以监控当前内存使用情况,并检查可能的内存泄露
  • Mutex--报告锁争用,以查看代码中使用的互斥锁的行为,以及应用程序是否在锁定调用上花费了太多时间
  • Block--显示 goroutine 阻塞等待同步原语的位置。

        在 Go 中,有一款分析工具名为 pprof 。首先,让我们了解如何以及何时启用 pprof; 然后,我们讨论最关键的配置文件类型。

启用 pprof 

        有几种方法可以启用 pprof 。例如,我们可以使用 net/http/pprof 包通过 HTTP提供分析数据:

package mainimport ("fmt""log""net/http"_ "net/http/pprof"
)func main() {http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {fmt.Fprintf(w, "")})log.Fatal(http.ListenAndServe(":80", nil))
}

导入 net/http/pprof 会产生副作用,使我们能够访问 pprof URL, http://host/debug/pprof。请注意,即使在生产环境中启用 pprof 也是安全的。影响性能的配置,如 CPU 分析,默认情况下不启用,也不会连续运行,它们仅在特定时间段内被激活。

现在我们已经了解了如何暴露 pprof 服务端,让我们讨论最常见的配置。

        CPU 分析

        CPU分析依赖于操作系统和信号。当它被激活时,应用程序默认通过 SIGPROF 信号要求操作系统每 10 ms 中断一次。当应用程序收到 SIGPROF 信号时,它会暂停当前活动并将执行转移到分析工具。分析工具收集诸如当前 goroutine 活动之类的数据,并汇总我们可以检索的执行统计信息。然后分析工具停止,应用程序继续执行直到下一个 SIGPROF 。

我们可以通过访问 /debug/pprof/profile 端点来激活 CPU 分析。默认情况下,访问此端点会执行 30 s 的 CPU 分析。在 30 s内,应用程序每 10 ms 中断一次。 请注意, 我们可以更改这两个默认值:可以使用 second 参数向端点传递分析应该持续多长时间(例如,/debug/pprof/profile?seconds=15),还可以更改中断速率 (甚至小于 10 ms)。但在大多数情况下,10 ms 应该足够了,在减小这个值 (意味着增加速率) 时,应该注意不要损害性能。 30 s 后,我们可下载 CPU 分析的结果。

        从这个文件中,我们可以使用 go tool 浏览到分析结果:

$ go tool pprof -http=:8080 <file>

此命令会打开一个显示调用图的 Web UI。下图显示了一个应用程序的例子。箭头越大,它越是热门路径。然后我们可以浏览到这张图表并获得执行参数。

        下图告诉我们,在 30s 内, decode 方法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/637410.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot集成Sleuth

引入Maven依赖 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-sleuth</artifactId></dependency> 配置yml文件 bootstrap.yml文件增加如下配置 注&#xff1a;这个配置不是必须要&#…

【结构型模式】装饰器模式

​一、装饰器模式概述 装饰器模式&#xff08;装饰者模式&#xff09;定义&#xff1a;装饰器模式动态地将责任附加到对象上。若要拓展功能&#xff0c;装饰者提供了比继承更有弹性地替代方案。&#xff08;对象结构型模型&#xff09;通俗点来说&#xff1a;动态的给一个对象增…

LCR 039

. - 力扣&#xff08;LeetCode&#xff09;. - 备战技术面试&#xff1f;力扣提供海量技术面试资源&#xff0c;帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/0ynMMM/ 给定非负整数数组 heights &#xff0c;数组中的数字用来表示…

AtCoder Beginner Contest 340

前面两道阅读理解直接跳过 C - Divide and Divide 大意 黑板上有一个数。 执行下列操作&#xff0c;直到黑板上的数全为1: 选择一个不小于2的整数&#xff0c;擦掉。写下和。需要的代价。 当不能继续操作时&#xff0c;总代价是多少&#xff1f; 思路 定义表示黑板上初…

【数学建模】优劣解距离法Topsis模型(含MATLAB代码)

TOPSIS法&#xff0c;全称 Technique for Order Preference by Similarity to an Ideal Solution&#xff0c;是由C.L.Hwang和K.Yoon于1981年首次提出的 。这是一种多目标决策分析中常用的有效方法&#xff0c;也被称作优劣解距离法 。 TOPSIS法的基本原理是通过检测评价对象与…

网盘_游戏_博客自动化部署(Nginx多项目部署)

目录 一.前提介绍 二.环境介绍 三.自述&#xff08;脚本&#xff09; 四.关于Nginx多项目部署 一.前提介绍 在我之前的博客里详细介绍了上述项目的部署&#xff0c;那么如何使用简单脚本自动部署和使用Nginx多项目部署是本文来介绍的基础篇章。 二.环境介绍 CentOS Linux…

书生·浦语2.0(InternLM2)大模型实战--Day04 XTuner微调 | 1.8B 多模态Agent(Part 2: 多模态部分)

视频地址&#xff1a; https://b23.tv/QUhT6ni课程文档&#xff1a;https://github.com/InternLM/Tutorial/blob/camp2/xtuner/readme.md作业文档&#xff1a;https://github.com/InternLM/Tutorial/blob/camp2/xtuner/homework.md 1. XTuner多模态训练与测试 在本节课中&…

[已解决]react打包部署

react打包部署 问题 npm install 命令无反应 思路 换成 yarn install 安装完hadoop的环境后&#xff0c;使用node的yarn会报错&#xff1a; 我们在cmd使用where yarn&#xff0c;如下&#xff1a; 看你想保留哪一个&#xff0c;我平时node用的多&#xff0c;就把hadoop的y…

Spring Boot中接收各种各样的参数

一、接收json参数&#xff0c;封装为Map 1.1、核心代码 /*** 接收json参数&#xff0c;封装为Map* param servletRequest* return* throws Exception*/ PostMapping("/getParam") public R getParam(HttpServletRequest servletRequest) throws Exception {Map<…

mysql基础19——日志

日志 mysql的日志种类非常多 通用查询日志 慢查询日志 错误日志 与时间有关联 二进制日志 中继日志 与主从服务器的同步有关 重做日志 回滚日志 与数据丢失有关 通用查询日志 记录了所有用户的连接开始时间和截至时间 以及给mysql服务器发送的所有指令 当数据异常时&…

个人开发 App 最简单方法:使用现代开发工具和平台

在移动应用市场的蓬勃发展下&#xff0c;个人开发者也有机会将自己的创意转化为实际的应用程序&#xff0c;并通过应用商店实现盈利。然而&#xff0c;对于许多初学者来说&#xff0c;如何开始个人开发一个应用可能会感到困惑。本文将介绍个人开发 App 的最简单方法&#xff0c…

C++修炼之路之list--C++中的双向循环链表

目录 前言 一&#xff1a;正式之前先回顾数据结构中的双向循环链表 二&#xff1a;list的简介 三&#xff1a;STL中list常用接口函数的介绍及使用 1.构造函数接口 2.list迭代器 范围for 3.数据的修改接口函数 4.list容量操作函数 5.list的迭代器失效 6.演示代码和测…