基于pyroscope-go项目性能数据持续收集

背景

在日常开发过程中,遇到类似崩溃或者cpu飚高时刻没法获取到有效的pprof数据,从而去优化修复项目。所以我们需要引入持续性分析且能够允许我们随着时间的推移了解系统资源的使用情况,从而定位、调试和修复性能相关的问题。

使用场景

  1. 查找代码中的性能问题

  2. 解决高 CPU 利用率的问题

  3. 定位并修复内存泄漏

  4. 理解应用程序的调用树

  5. 跟踪指标随时间的变化

性能及原理

  1. 关于采集文件存储:在官方文档有说明:为避免丢失最新数据,当它检测到数据路径所在的卷接近磁盘不足,Pyroscope 将删除最旧的块。

  2. pyroscope是定时从runtime提供的几个函数获取系统指标数据,以及pprof上报是通过http上传到远程server中,只要上传和获取频率不是非常大,对业务本身影响并不大

部署

colobu.com/2022/01/27/...

为便于使用,目前采用的是Go Agent ,采用push模式,参考文档

dockerfile 复制代码
docker run -it  --name=pyroscope-go -p 4040:4040 pyroscope/pyroscope:latest server
go 复制代码
go get github.com/grafana/pyroscope-go

package main

import "github.com/grafana/pyroscope-go"

func main() {
  // These 2 lines are only required if you're using mutex or block profiling
  // Read the explanation below for how to set these rates:
  runtime.SetMutexProfileFraction(5)
  runtime.SetBlockProfileRate(5)

  pyroscope.Start(pyroscope.Config{
    ApplicationName: "simple.golang.app", //自定义应用名称

    // replace this with the address of pyroscope server
    ServerAddress:   "http://pyroscope-server:4040", //本地是http://127.0.0.1:4040

    // you can disable logging by setting this to nil
    Logger:          pyroscope.StandardLogger,

    // you can provide static tags via a map:
    Tags:            map[string]string{"hostname": os.Getenv("HOSTNAME")},

    ProfileTypes: []pyroscope.ProfileType{
      // these profile types are enabled by default:
      pyroscope.ProfileCPU,
      pyroscope.ProfileAllocObjects,
      pyroscope.ProfileAllocSpace,
      pyroscope.ProfileInuseObjects,
      pyroscope.ProfileInuseSpace,

      // these profile types are optional:
      pyroscope.ProfileGoroutines,
      pyroscope.ProfileMutexCount,
      pyroscope.ProfileMutexDuration,
      pyroscope.ProfileBlockCount,
      pyroscope.ProfileBlockDuration,
    },
  })

  // your code goes here
}

只要以上两步,访问127.0.0.1:4040你就可以看到布灵布灵的火焰图了

目前我本地只是做了pprof的收集分析,大佬们后续可以考虑线上k8s环境中借鉴七猫技术团队的方案的引入holmes,发现业务性能问题,和上报机制

本文参考文档如下:

github.com/grafana/pyr...

github.com/mosn/holmes...

相关推荐
文心快码BaiduComate5 分钟前
里程碑突破 | 文心快码中标国家开发银行代码研发助手项目
前端·后端·架构
她的男孩8 分钟前
ForgeAdmin 新成员:AI 赋能的数据可视化大屏平台
后端
songcream112 分钟前
Spring Boot资料整理
java·spring boot·后端
U盘失踪了14 分钟前
go 常量
开发语言·后端·golang
techdashen15 分钟前
Go 的新垃圾回收器 Green Tea:一个降低GC CPU开销的大工程
开发语言·后端·golang
披着羊皮不是狼18 分钟前
(8):实现双删(MySQL+Redis)
spring boot·后端
鬼蛟37 分钟前
springcloud
后端·spring·spring cloud
lhbian41 分钟前
PHP vs Java vs Go:编程语言终极对比
java·spring boot·后端·kafka·linq
掘金者阿豪42 分钟前
实测4大AI做PPT神器:千问 vs Kimi vs 豆包 vs 扣子,谁才是最强生产力?(附完整对比)
后端
石榴树下的七彩鱼1 小时前
身份证 OCR 识别 API 接入详解(Python / Java 示例)
java·开发语言·人工智能·后端·python·ocr·api