Go: sysmon, 运行时监控

ℹ️ 本文基于Go1.14。

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

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

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

范围

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

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

 

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

频率

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

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

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

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

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

编译自:https://medium.com/@blanchon.vincent/go-sysmon-runtime-monitoring-cff9395060b5

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据