当前位置:首页 > 科技  > 软件

Go 标准库想增加 metrics 指标,你支持吗?

来源: 责编: 时间:2023-10-13 14:37:45 166观看
导读大家好,我是煎鱼。在 Go 的标准库中,有一个神奇的标准库 runtime/metrics,这个标准库提供了一系列预定义好的 Go 自身的相关指标。如果没有编写过基础监控库或者关注的比较少的朋友可能会没接触到这类指标,甚至不知道有这

大家好,我是煎鱼。x5J28资讯网——每日最新资讯28at.com

在 Go 的标准库中,有一个神奇的标准库 runtime/metrics,这个标准库提供了一系列预定义好的 Go 自身的相关指标。x5J28资讯网——每日最新资讯28at.com

如果没有编写过基础监控库或者关注的比较少的朋友可能会没接触到这类指标,甚至不知道有这些值。但我相信你在监控图标中肯定看到过。x5J28资讯网——每日最新资讯28at.com

本文分两个部分,第一个部分是快速了解现有的 metrics 指标,第二个部分是了解现在社区希望追加到标准库的 metrics 指标内容。x5J28资讯网——每日最新资讯28at.com

一起看看社区讨论的方向和内容。x5J28资讯网——每日最新资讯28at.com

快速了解 runtime/metrics

以下是一个快速 Demo。代码如下:x5J28资讯网——每日最新资讯28at.com

func main() { descs := metrics.All() samples := make([]metrics.Sample, len(descs)) for i := range samples {  samples[i].Name = descs[i].Name } metrics.Read(samples) for _, sample := range samples {  name, value := sample.Name, sample.Value  switch value.Kind() {  case metrics.KindUint64:   fmt.Printf("%s: %d/n", name, value.Uint64())  case metrics.KindFloat64:   fmt.Printf("%s: %f/n", name, value.Float64())  case metrics.KindFloat64Histogram:   fmt.Printf("%s: %f/n", name, medianBucket(value.Float64Histogram()))   ...  } }}func medianBucket(h *metrics.Float64Histogram) float64 { total := uint64(0) for _, count := range h.Counts {  total += count } thresh := total / 2 total = 0 for i, count := range h.Counts {  total += count  if total >= thresh {   return h.Buckets[i]  } } panic("should not happen")}

输出结果:x5J28资讯网——每日最新资讯28at.com

/cgo/go-to-c-calls:calls: 0/cpu/classes/gc/mark/assist:cpu-seconds: 0.000000/cpu/classes/gc/mark/dedicated:cpu-seconds: 0.000000.../gc/cycles/automatic:gc-cycles: 0/gc/cycles/forced:gc-cycles: 0/gc/cycles/total:gc-cycles: 0/gc/gogc:percent: 100/gc/gomemlimit:bytes: 9223372036854775807/gc/heap/allocs-by-size:bytes: 8193.000000/gc/heap/allocs:bytes: 56832/gc/heap/allocs:objects: 6/gc/heap/frees-by-size:bytes: 1.000000/gc/heap/frees:bytes: 0/gc/heap/frees:objects: 0/gc/heap/goal:bytes: 4194304...

里面包含了相当多的 Go 系统指标。完整的代码运行和输出可以查看 https://go.dev/play/p/CKASbysqX9xx5J28资讯网——每日最新资讯28at.com

我梳理了一张对照清单。其中 10 个指标如下:x5J28资讯网——每日最新资讯28at.com

序号
x5J28资讯网——每日最新资讯28at.com

指标
x5J28资讯网——每日最新资讯28at.com

含义
x5J28资讯网——每日最新资讯28at.com

1
x5J28资讯网——每日最新资讯28at.com

/cgo/go-to-c-calls:calls
x5J28资讯网——每日最新资讯28at.com

当前进程从 Go 调用到 C 的次数
x5J28资讯网——每日最新资讯28at.com

2
x5J28资讯网——每日最新资讯28at.com

/cpu/classes/gc/mark/assist:cpu-seconds
x5J28资讯网——每日最新资讯28at.com

预计执行 GC 程序所花费的 CPU 总时长,以协助 GC 并防止其落后于应用程序
x5J28资讯网——每日最新资讯28at.com

3
x5J28资讯网——每日最新资讯28at.com

/cpu/classes/gc/mark/dedicated:cpu-seconds
x5J28资讯网——每日最新资讯28at.com

在专门用于执行 GC 任务的 CPU 处理器(根据 GOMAXPROCS 的定义)上执行 GC 任务预计需要花费的 CPU 总时长
x5J28资讯网——每日最新资讯28at.com

4
x5J28资讯网——每日最新资讯28at.com

/cpu/classes/gc/mark/idle:cpu-seconds
x5J28资讯网——每日最新资讯28at.com

在空闲 CPU 资源上执行 GC 任务所花费的 CPU 总时间
x5J28资讯网——每日最新资讯28at.com

5
x5J28资讯网——每日最新资讯28at.com

/cpu/classes/gc/pause:cpu-seconds
x5J28资讯网——每日最新资讯28at.com

GC 暂停应用程序预计所花费的 CPU 总时长
x5J28资讯网——每日最新资讯28at.com

6
x5J28资讯网——每日最新资讯28at.com

/gc/cycles/automatic:gc-cycles
x5J28资讯网——每日最新资讯28at.com

Go Runtime 程序已完成的 GC 循环次数。
x5J28资讯网——每日最新资讯28at.com

7
x5J28资讯网——每日最新资讯28at.com

/gc/gogc:percent
x5J28资讯网——每日最新资讯28at.com

用户配置的堆大小目标百分比
x5J28资讯网——每日最新资讯28at.com

8
x5J28资讯网——每日最新资讯28at.com

/gc/heap/allocs:objects
x5J28资讯网——每日最新资讯28at.com

应用程序触发的堆分配累计计数
x5J28资讯网——每日最新资讯28at.com

9
x5J28资讯网——每日最新资讯28at.com

/memory/classes/heap/free:bytes
x5J28资讯网——每日最新资讯28at.com

Go Runtime 对物理内存的可用空间大小的预估(完全空闲并可返回底层系统但尚未返回的内存)
x5J28资讯网——每日最新资讯28at.com

10
x5J28资讯网——每日最新资讯28at.com

/sched/gomaxprocs:threads
x5J28资讯网——每日最新资讯28at.com

当前 runtime.GOMAXPROCS 的值,或是可以同时执行用户级 Go 代码的操作系统线程数。x5J28资讯网——每日最新资讯28at.com

对于完整指标有兴趣的可以查看:https://pkg.go.dev/runtime/metrics#hdr-Supported_metricsx5J28资讯网——每日最新资讯28at.com

更多的 metrics 指标

最近在 Go 社区中有同学发起了一项讨论《metrics for the standard library[1]》,希望探讨和在其他标准库中添加更多的 metrics 指标,提供更多的可观察性。x5J28资讯网——每日最新资讯28at.com

比较多同学期望的是网络、延迟类的指标,针对性能、错误等。如下几种场景:x5J28资讯网——每日最新资讯28at.com

  • net/http 服务端:
  • 处理延迟。
  • 请求/响应体大小。
  • 恐慌(panic)、恢复(recover)。
  • 错误/警告(触发 net/http.Server.ErrorLog 的所有内容)
  • 被拒绝的无效请求。
  • net/http 客户端:
  • 调用延迟。x5J28资讯网——每日最新资讯28at.com

  • 请求/响应体大小x5J28资讯网——每日最新资讯28at.com

  • 连接池相关。x5J28资讯网——每日最新资讯28at.com

  • database/sql 客户端:x5J28资讯网——每日最新资讯28at.com

  • 查询延迟。x5J28资讯网——每日最新资讯28at.com

  • 响应大小。x5J28资讯网——每日最新资讯28at.com

  • 连接池相关。x5J28资讯网——每日最新资讯28at.com

  • net 网络包相关:x5J28资讯网——每日最新资讯28at.com

  • 例如 TCP、UDP 等,对应的打开连接的数量、连接状态(空闲、激活、关闭)、连接错误等。x5J28资讯网——每日最新资讯28at.com

  • 例如 TLS,在握手阶段相关的指标,握手持续时间、握手失败计数等。x5J28资讯网——每日最新资讯28at.com

新提及的 metrics 指标有没有满足你的需求呢,或者有没有更多的补充?x5J28资讯网——每日最新资讯28at.com

总结

整体上会发现大家对于 Go 标准库的指标诉求,更多的趋向于底层包。因为无论你用的是什么开源仓库,其绝大部分都是基于上述提到的包。x5J28资讯网——每日最新资讯28at.com

在现阶段,如果自己的 Go 业务应用程序去记录这些指标,就需要再封装一层,每一个包,例如:ORM 就需要去实现一遍插件等。x5J28资讯网——每日最新资讯28at.com

而第三方库实现不会把 metrics 这类非核心功能直接加入初始化实现中。因此官方标准库对 metrics 的支持是非常有必要的。x5J28资讯网——每日最新资讯28at.com

至少这样就不用每个团队都搞一遍 net/http、database/sql 等的延迟调用指标的配置和设置了。x5J28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-13579-0.htmlGo 标准库想增加 metrics 指标,你支持吗?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Java与第三方API集成:调用外部服务的最佳实践

下一篇: 深入探索Elasticsearch:高级查询技巧与性能优化策略

标签:
  • 热门焦点
  • 摸鱼心法第一章——和配置文件说拜拜

    摸鱼心法第一章——和配置文件说拜拜

    为了能摸鱼我们团队做了容器化,但是带来的问题是服务配置文件很麻烦,然后大家在群里进行了“亲切友好”的沟通图片图片图片图片对比就对比,简单对比下独立配置中心和k8s作为配
  • 使用Webdriver-manager解决浏览器与驱动不匹配所带来自动化无法执行的问题

    使用Webdriver-manager解决浏览器与驱动不匹配所带来自动化无法执行的问题

    1、前言在我们使用 Selenium 进行 UI 自动化测试时,常常会因为浏览器驱动与浏览器版本不匹配,而导致自动化测试无法执行,需要手动去下载对应的驱动版本,并替换原有的驱动,可能还
  • 2023年,我眼中的字节跳动

    2023年,我眼中的字节跳动

    此时此刻(2023年7月),字节跳动从未上市,也从未公布过任何官方的上市计划;但是这并不妨碍它成为中国最受关注的互联网公司之一。从2016-17年的抖音强势崛起,到2018年的“头腾
  • 本地生活这块肥肉,拼多多也想吃一口

    本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页“充值中心”入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为“纯欲天花板”的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • 2纳米决战2025

    2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • AMD的AI芯片转单给三星可能性不大 与台积电已合作至2nm制程

    AMD的AI芯片转单给三星可能性不大 与台积电已合作至2nm制程

    据 DIGITIMES 消息,英伟达 AI GPU 出货逐季飙升,接下来 AMD MI 300 系列将在第 4 季底量产。而半导体业内人士表示,近日传出 AMD 的 AI 芯片将转单给
  • OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    据此前官方宣布,OPPO将于7月25日也就是今天下午14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖
  • SN570 NVMe SSD固态硬盘 价格与性能兼具

    SN570 NVMe SSD固态硬盘 价格与性能兼具

    SN570 NVMe SSD固态硬盘是西部数据发布的最新一代WD Blue系列的固态硬盘,不仅闪存技术更为精进,性能也得到了进一步的跃升。WD Blue SN570 NVMe SSD的包装外
Top
Baidu
map