go 毫秒时间戳_Go: sysmon, 运行时监控

c06cf4932951ad20b00c4984aecf7066.png

ℹ️ 本文基于Go1.14。

Go标准库专门用于监控程序帮助解决程序可能遇到的瓶颈的线程称为sysmon。sysmon并没有链接到GMP模型中的任意P上,所以不会被调度器调度,因此会始终处于运行状态。

5abef70f25baed2a2c36d567b4bbbe91.png

更多关于GMP模型的信息请参阅 “Go: Goroutine, 系统线程和CPU管理”

此外,你将不会通过go tool trace跟踪到这个线程。

范围

该线程作用广泛并涉及以下方面:

  • 由应用程序创建的计时器(timers)。sysmon查看应该在运行但仍在等待的计时器。在这种情况下,Go将查看空闲的M和P列表以尽快运行它们。
  • 网络轮训器(net poller )和系统调用( system calls)。它运行网络操作中阻塞的goroutines。
  • 如果垃圾收集器(garbage collector)已经很长时间没有运行(超过2分钟),sysmon将强制一轮垃圾回收。

ec4345501be8251868eb0bc9b17fec4d.png
  • 长时间运行goroutine的抢占。任何运行超过10毫秒的goroutine将会被抢占把运行时间留给其他goroutines。

频率

sysmon非常聪明,无事可做时不会消耗资源。它的频率是动态的,并取决于正在运行程序的当前活动。

初始频率是20纳秒,意味着线程一直在检查。然后,经过数轮后,如果sysmon还是无事可做,频率将会加倍一直可以增加到10毫秒的频率。如果你的程序没有很多系统调用或者长时间运行的goroutine,则sysmon将会大多数时间维持10毫秒的频率,这将给你的应用程序带来非常小的开销。

该线程还能检测何时不应运行。这是两种情况:

  • 垃圾收集器将要运行时。sysmon将会在回收结束后恢复运行。
  • 所有线程都处于空闲时。

在这两种情况下,sysmon都会休眠并且不会消耗任何资源。

编译自: https:// medium.com/@blanchon.vi ncent/go-sysmon-runtime-monitoring-cff9395060b5
博客地址: https://www. chenjie.info/2628

21c5f6e7ced9881cfaed0a1435188963.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值