我正在分析一个程序,其中绝大多数 (86%) 的时间都花在两个运行时函数上:kevent 和 selectgo。我理解select,但我不知道kevent是什么(所以我不知道从哪里开始优化):

Showing top 10 nodes out of 33
      flat  flat%   sum%        cum   cum%
   114.63s 65.79% 65.79%    114.63s 65.79%  runtime.kevent /usr/local/Cellar/go/1.9.2/libexec/src/runtime/sys_darwin_amd64.s
    19.26s 11.05% 76.85%     35.90s 20.60%  runtime.selectgo /usr/local/Cellar/go/1.9.2/libexec/src/runtime/select.go

最佳答案

这是 network poller
有多种实现方式:

  • epoll for linux
  • kevent queue 用于达尔文和其他一些人

  • 由于在达尔文,您会看到 kevent
    基本上,这是等待 I/O 所花费的时间。

    请注意,它称为 netpoll,但它通常适用于文件描述符,因此它可能是网络通信,但也可能是文件 I/O。

    以下是有关 kqueueepoll 的更多详细信息。

    关于go - golang 程序配置文件中的 runtime.kevent 是什么?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48116704/

    10-11 10:39