ℹ️ 本文基于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